本文實(shí)例講述了Java責(zé)任鏈模式定義與用法。分享給大家供大家參考,具體如下:
使很多對(duì)象都有處理請(qǐng)求的機(jī)會(huì),從而避免請(qǐng)求的發(fā)送者和接受者之間的耦合關(guān)系。將這些對(duì)象連成一條鏈,并沿著這條鏈傳遞該請(qǐng)求,直到有一個(gè)對(duì)象處理它為止
責(zé)任鏈模式主要包括以下幾個(gè)角色
1、處理者:處理者是一個(gè)接口,負(fù)責(zé)規(guī)定具體處理者處理用戶請(qǐng)求的方法以及具體處理者設(shè)置后繼處理對(duì)象的方法
2、具體處理者:具體處理者是實(shí)現(xiàn)處理接口的類的實(shí)例,具體處理者通過(guò)調(diào)用處理接口規(guī)定的方法處理用戶的請(qǐng)求,既在接到用戶的請(qǐng)求后,處理者將調(diào)用接口規(guī)定的方法,在執(zhí)行該方法的過(guò)程中,如果發(fā)現(xiàn)能處理用戶的請(qǐng)求,就處理用戶的請(qǐng)求。如果發(fā)現(xiàn)處理不了就交給下一個(gè)處理者進(jìn)行處理。
例如一個(gè)圖書檢索的程序,根據(jù)圖書類別將圖書分為了N個(gè)種類,然后創(chuàng)建若干個(gè)種類的對(duì)象,每個(gè)對(duì)象對(duì)一個(gè)種類進(jìn)行檢索。為了能更好的管理這些對(duì)象,可以將這額對(duì)象組織成一個(gè)責(zé)任鏈,當(dāng)用戶需要鑒定書籍時(shí),系統(tǒng)可以讓責(zé)任鏈上的第一個(gè)對(duì)象來(lái)處理用戶的請(qǐng)求,這個(gè)對(duì)象首先檢索自己是否能夠處理用戶的請(qǐng)求,如果能處理就反饋并返回處理內(nèi)容。如果不能處理則交給下一個(gè)處理對(duì)象進(jìn)行處理。
1
2
3
4
5
6
7
8
9
10
11
12
|
package org.zhy.design.demo; /** * 處理接口 * @author zhengyi * */ public interface Handler { //根據(jù)書的ID進(jìn)行檢索 public abstract void Search( int id); //下一個(gè)處理者 參數(shù)為實(shí)現(xiàn)處理接口的實(shí)現(xiàn)類 public abstract void nextHandler(Handler han); } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
package org.zhy.design.demo; import java.util.ArrayList; import java.util.List; /** * 文學(xué)類的書籍檢索 * @author zhengyi * */ public class WenXue implements Handler{ private Handler han; //下一個(gè)處理者 private List<Integer> list; //模擬文學(xué)類書籍的編號(hào) public WenXue(){ list= new ArrayList<Integer>(); list.add( 1 ); list.add( 2 ); list.add( 3 ); list.add( 4 ); list.add( 5 ); } @Override public void nextHandler(Handler han) { this .han=han; //給下一個(gè)處理者賦值 } @Override public void Search( int id) { if (list.contains(id)){ //檢索list中是否存在此ID的書籍,如果存在則打印 System.out.println( "恭喜您,您檢索的書籍是文學(xué)類的" ); } else { //如果沒有此書籍則交給下一個(gè)處理者進(jìn)行處理 if (han!= null ){ han.Search(id); } } } } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
package org.zhy.design.demo; import java.util.ArrayList; import java.util.List; /** * 計(jì)算機(jī)類的書籍 * @author zhengyi * */ public class JiSuanJi implements Handler { private Handler han; private List<Integer> list; public JiSuanJi(){ list= new ArrayList<Integer>(); list.add( 6 ); list.add( 7 ); list.add( 8 ); list.add( 9 ); list.add( 10 ); } @Override public void nextHandler(Handler han) { this .han=han; } @Override public void Search( int id) { if (list.contains(id)){ System.out.println( "恭喜你,此書記在計(jì)算機(jī)類" ); } else { if (han!= null ){ han.Search(id); } } } } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
package org.zhy.design.demo; public class Appliction { private Handler jisuanji,wenxue; public void createHandler(){ jisuanji= new JiSuanJi(); wenxue= new WenXue(); jisuanji.nextHandler(wenxue); //指定下一個(gè)處理者 } public void search( int id){ jisuanji.Search(id); //第一個(gè)處理者進(jìn)行篩選處理 } public static void main(String[] args) { Appliction app= new Appliction(); app.createHandler(); app.search( 10 ); } } |
適合使用責(zé)任鏈模式的情況
1、在許多對(duì)象可以處理用戶請(qǐng)求的時(shí)候
2、希望用戶不必明確處理者的時(shí)候,同時(shí)向多個(gè)處理者發(fā)送請(qǐng)求
3、程序希望動(dòng)態(tài)的訂制可處理用戶請(qǐng)求的集合對(duì)象
希望本文所述對(duì)大家java程序設(shè)計(jì)有所幫助。