Java责任链模式(Chain of Responsibility模式)

简介:

Chain of Responsibility定义:Chain of Responsibility(CoR) 是用一系列类(classes)试图处理一个请求request,这些类之间是一个松散的耦合,唯一共同点是在他们之间传递request。也就是说,来了一个请求,A类先处理,如果没有处理,就传递到B类处理,如果没有处理,就传递到C类处理,就这样象一个链条(chain)一样传递下去。

如何使用责任链模式

虽然这一段是如何使用CoR,但是也是演示什么是CoR。

有一个Handler接口: public interface Handler{   public void handleRequest(); }

这是一个处理request的事例, 如果有多种request,比如 请求帮助 请求打印 或请求格式化:

◆ 最先想到的解决方案是:在接口中增加多个请求:

 
  1. public interface Handler{

  2. public void handleHelp();

  3. public void handlePrint();

  4. public void handleFormat();

  5. }

具体是一段实现接口Handler代码:

 
  1. public class ConcreteHandler implements Handler{

  2. private Handler successor;

  3. public ConcreteHandler(Handler successor){

  4. this.successor=successor;

  5. }

  6. public void handleHelp(){

  7. //具体处理请求Help的代码

  8. }

  9. public void handlePrint(){

  10. //如果是print 转去处理Print

  11.     successor.handlePrint();

  12. }

  13. public void handleFormat(){

  14. //如果是Format 转去处理format

  15.     successor.handleFormat();

  16. }

  17. }

一共有三个这样的具体实现类,上面是处理help,还有处理Print 处理Format这大概是我们最常用的编程思路。

虽然思路简单明了,但是有一个扩展问题,如果我们需要再增加一个请求request种类,需要修改接口及其每一个实现。

◆ 第二方案:将每种request都变成一个接口,因此我们有以下代码 :

 
  1. public interface HelpHandler{

  2. public void handleHelp();

  3. }

  4. public interface PrintHandler{

  5. public void handlePrint();

  6. }

  7. public interface FormatHandler{

  8. public void handleFormat();

  9. }

  10. public class ConcreteHandler

  11. implements HelpHandler,PrintHandler,FormatHandlet{

  12. private HelpHandler helpSuccessor;

  13. private PrintHandler printSuccessor;

  14. private FormatHandler formatSuccessor;

  15. public ConcreteHandler(HelpHandler helpSuccessor,PrintHandler printSuccessor,FormatHandler             formatSuccessor)

  16. {

  17. this.helpSuccessor=helpSuccessor;

  18. this.printSuccessor=printSuccessor;

  19. this.formatSuccessor=formatSuccessor;

  20. }

  21. public void handleHelp(){

  22. …….

  23. }

  24. public void handlePrint(){this.printSuccessor=printSuccessor;}

  25. public void handleFormat(){this.formatSuccessor=formatSuccessor;}

  26. }

这个办法在增加新的请求request情况下,只是节省了接口的修改量,接口实现ConcreteHandler还需要修改。而且代码显然不简单美丽。

◆ 解决方案3:在Handler接口中只使用一个参数化方法:

 
  1. public interface Handler{

  2. public void handleRequest(String request);

  3. }

那么Handler实现代码如下:

 
  1. public class ConcreteHandler implements Handler{

  2. private Handler successor;

  3. public ConcreteHandler(Handler successor){

  4. this.successor=successor;

  5. }

  6. public void handleRequest(String request){

  7. if (request.equals("Help")){

  8. //这里是处理Help的具体代码

  9. }else

  10. //传递到下一个

  11.       successor.handle(request);

  12. }

  13. }

  14. }

这里先假设request是String类型,如果不是怎么办?当然我们可以创建一个专门类Request

◆ 最后解决方案:接口Handler的代码如下:

 
  1. public interface Handler{

  2. public void handleRequest(Request request);

  3. }

Request类的定义:

 
  1. public class Request{

  2. private String type;

  3. public Request(String type){this.type=type;}

  4. public String getType(){return type;}

  5. public void execute(){

  6. //request真正具体行为代码

  7. }

  8. }

那么Handler实现代码如下:

 
  1. public class ConcreteHandler implements Handler{

  2. private Handler successor;

  3. public ConcreteHandler(Handler successor){

  4. this.successor=successor;

  5. }

  6. public void handleRequest(Request request){

  7. if (request instanceof HelpRequest){

  8. //这里是处理Help的具体代码

  9. }else if (request instanceof PrintRequst){

  10.       request.execute();

  11. }else

  12. //传递到下一个

  13.       successor.handle(request);

  14. }

  15. }

  16. }

这个解决方案就是CoR,在一个链上,都有相应职责的类,因此叫Chain of Responsibility。

  • CoR的优点:因为无法预知来自外界的请求是属于哪种类型,每个类如果碰到它不能处理的请求只要放弃就可以。无疑这降低了类之间的耦合性。

  • CoR的缺点是效率低,因为一个请求的完成可能要遍历到最后才可能完成,当然也可以用树的概念优化。 在Java AWT1.0中,对于鼠标按键事情的处理就是使用CoR,到Java.1.1以后,就使用Observer代替CoR。 扩展性差,因为在CoR中,一定要有一个统一的接口Handler.局限性就在这里。


原文发布时间为:2018-08-30

本文作者:HARRIES

本文来自云栖社区合作伙伴“Java杂记”,了解相关信息可以关注“Java杂记”。

相关文章
|
2月前
|
传感器 人工智能 数据可视化
Java智慧工地监管一体化云平台APP源码 SaaS模式
安全隐患排查 1.可在电脑端、手机端对安全隐患数据进行记录、查询 2.能够实现安全隐患发起、整改、复查的闭环管理 3.具备对安全隐患数据进行统计、可视化分析、信息推送等功能 4.包含对危险性较大的分部分项工程进行巡查记录功能
55 4
|
3月前
|
设计模式 存储 算法
Java 设计模式最佳实践:三、行为模式
Java 设计模式最佳实践:三、行为模式
|
3月前
|
小程序 Java 数据管理
Java前后端分离架构开发的智慧校园电子班牌系统源码(SaaS模式)
.智慧校园设备管理: 设备管理主要对班级中正在使用的电子智慧班牌进行管理,基本功能包含(开关机状态、班级信息、设备型号、开关机信息、电子智慧班牌截屏信息、教师编号、设备ID、在线和离线状态、电子智慧班牌更新时间等)
40 0
|
3月前
|
设计模式 Dubbo Java
聊聊Java设计模式-责任链模式
责任链模式(Chain Of Responsibility Design Pattern),也叫做职责链,是将请求的发送和接收解耦,让多个接收对象都有机会处理这个请求。当有请求发生时,可将请求沿着这条链传递,直到有对象处理它为止。
80 1
聊聊Java设计模式-责任链模式
|
3月前
|
消息中间件 Java
Java操作RabbitMQ单一生产-消费者模式
Java操作RabbitMQ单一生产-消费者模式
29 0
|
4月前
|
Java Maven
[Java ] jdk升级 bug java: -source 8 中不支持 instanceof 中的模式匹配 (请使用 -source 16 或更高版本以启用 instanceof 中的模式匹配)
[Java ] jdk升级 bug java: -source 8 中不支持 instanceof 中的模式匹配 (请使用 -source 16 或更高版本以启用 instanceof 中的模式匹配)
133 0
|
7天前
|
存储 Java
模式匹配魔法:Java 21中switch语句的巨大进化
模式匹配魔法:Java 21中switch语句的巨大进化
10 0
|
29天前
|
传感器 人工智能 数据可视化
Java智慧工地监管一体化云平台APP源码 SaaS模式
高支模监测:高支模立杆及倾斜角度,高支模立杆的荷载,架体的水平位移以及模板沉降情况,当检测数据超过预警值时,实时报警。
30 2
|
1月前
|
设计模式 Java
Java责任链模式
Java责任链模式
14 0
|
1月前
|
Java
Java的模式
Java的模式
7 0