JAVA 设计模式 职责链模式

用途

职责链模式 (Chain Of Responsibility)

使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。 将这个对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止。

职责链模式是一种行为型模式

结构

图-职责链模式

Handler : 定义一个处理请求的接口。(可选的)实现设置后继者的方法。

abstract class Handler {
 protected Handler successor;
 public void SetSuccesssor(Handler successor) {
 this.successor = successor;
     }
 
 public abstract void HandlerRequest(int request);
 }

ConcreteHandler : 处理它所负责的请求,可以访问它的后继者,如果可处理该请求,就处理之,否则就将请求转发给它的后继者。

class ConcreteHandler1 extends Handler {
     @Override
 public void HandlerRequest(int request) {
 if (request >= 0 && request < 10) {
             System.out.println("ConcreteHandler1 处理请求 " + request);
         } else if (null != successor) {
             successor.HandlerRequest(request);
         }
     }
 }
 
 class ConcreteHandler2 extends Handler {
     @Override
 public void HandlerRequest(int request) {
 if (request >= 10 && request < 20) {
             System.out.println("ConcreteHandler2 处理请求 " + request);
         } else if (null != successor) {
             successor.HandlerRequest(request);
         }
     }
 }
 
 class ConcreteHandler3 extends Handler {
     @Override
 public void HandlerRequest(int request) {
 if (request >= 20 && request < 30) {
             System.out.println("ConcreteHandler3 处理请求 " + request);
         } else if (null != successor) {
             successor.HandlerRequest(request);
         }
     }
 }

Client : 需要设置一个职责链的各环节对象串联起来。

public class ChainOfResponsibilityPattern {
 public static void main(String[] args) {
         Handler h1 = new ConcreteHandler1();
         Handler h2 = new ConcreteHandler2();
         Handler h3 = new ConcreteHandler3();
         h1.SetSuccesssor(h2);
         h2.SetSuccesssor(h3);
 
 int[] requests = {2, 29, 9, 15, 4, 19};
 for (int i : requests) {
             h1.HandlerRequest(i);
         }
     }
 }

推荐

本文属于 JAVA设计模式系列

参考资料

《大话设计模式》《HeadFirst设计模式》

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏云瓣

React16.x特性剪辑

在 16 之前的版本的渲染过程可以想象成一次性潜水 30 米,在这期间做不了其它事情(Stack Reconciler);

742
来自专栏mySoul

TypeScript 接口

// 注意在上方中并不会对静态的,进行检查。只会对非静态的部分,即非构造函数部分进行检查

994
来自专栏IMWeb前端团队

React高阶组件(译)

本文作者:IMWeb zzbozheng 原文出处:IMWeb社区 未经同意,禁止转载 原文:https://daveceddia.com/extra...

1776
来自专栏大内老A

ASP.NET MVC下的异步Action的定义和执行原理

Visual Studio提供的Controller创建向导默认为我们创建一个继承自抽象类Controller的Controller类型,这样的Controll...

2115
来自专栏大大的微笑

初识ActiveMQ

①.消息传递方式介绍: Activemq支持两种方式的消息传递:     广播模式:1-n的方式,是一种发布订阅模式,像腾讯新闻那样,只要我们微信关注了腾讯新闻...

5377
来自专栏菩提树下的杨过

温故而知新:HttpApplication,HttpModule,HttpContext及Asp.Net页生命周期

IIS在接到一个新的http请求后,最终会调用asp.net_isapi.dll的ISAPI扩展(特指IIS6.0环境,iis7.0的应用程序池默认为集成方式,...

1745
来自专栏Java编程技术

Dubbo剖析-整体架构分析

工欲善其事,必先利其器,前面通过几篇文章简单的介绍了如何使用Dubbo搭建一个简单的分布式系统,在接下来的的一段时间就来研究Dubbo原理设计,本文作为原理设计...

793
来自专栏Java编程技术

Dubbo剖析-服务消费方Invoker到客户端接口的转换

前面dubbo整体架构分析里面我们讲解了服务消费者消费一个服务的详细过程是,首先 调用 Protocol 的 refer 方法生成 Invoker 实例,接下来...

913
来自专栏大内老A

WCF技术剖析之二十三:服务实例(Service Instance)生命周期如何控制[中篇]

在[第1篇]中,我们介绍了WCF关于实例管理一些基本的知识点,包括InstanceContext、InstanceContextMode、已经如何通过Servi...

1786
来自专栏大内老A

EndpointAddress——不只是一个Uri[下篇]

《上篇》对AddressHeader在服务端和客户端的作用,以及如何通过配置和编成的方式设置AddressHeader进行了详细介绍。现在我们通过一个实例来演示...

1867

扫码关注云+社区