专栏首页xingoo, 一个梦想做发明家的程序员【设计模式】—— 职责链模式ChainOfResponsibility

【设计模式】—— 职责链模式ChainOfResponsibility

  模式意图

  避免请求的发送者,和接受者过度的耦合在一起。一个请求者只需要发送一个请求即可,它的请求具体由后面哪个对象进行响应,并不需要关心。而请求的接受者可以自己处理它,也可以把它像链条一样向后传。

  因此,请求也就意味着有可能丢失,或者说没有确切的安全保障。

  应用场景

  1 降低耦合度

  2 增强指派职责的灵活性

  3 不保证被接受

  模式结构

Handler 定义一个接口,实现向后传递的过程

 1 abstract class Handler{
 2     protected Handler successor;
 3     
 4     public abstract void handleRequest();
 5     
 6     public Handler getSuccessor() {
 7         return successor;
 8     }
 9     
10     public void setSuccesor(Handler successor) {
11         this.successor = successor;
12     }
13     
14 }

ConcreteHandler 可以负责请求,也可以向后传递

 1 class ConcreteHandler extends Handler{
 2     public void handleRequest(){
 3         if(getSuccessor() != null){
 4             System.out.println("getSuccessor !");
 5             getSuccessor().handleRequest();
 6         }else{
 7             System.out.println("handle in this! request()!");
 8         }
 9     }
10 }

  全部代码

 1 package com.xingoo;
 2 abstract class Handler{
 3     protected Handler successor;
 4     
 5     public abstract void handleRequest();
 6     
 7     public Handler getSuccessor() {
 8         return successor;
 9     }
10     
11     public void setSuccesor(Handler successor) {
12         this.successor = successor;
13     }
14     
15 }
16 class ConcreteHandler extends Handler{
17     public void handleRequest(){
18         if(getSuccessor() != null){
19             System.out.println("getSuccessor !");
20             getSuccessor().handleRequest();
21         }else{
22             System.out.println("handle in this! request()!");
23         }
24     }
25 }
26 public class Client {
27     public static void main(String[] args) {
28         Handler handle1,handle2,handle3;
29         handle1 = new ConcreteHandler();
30         handle2 = new ConcreteHandler();
31         handle3 = new ConcreteHandler();
32         handle1.setSuccesor(handle2);
33         handle2.setSuccesor(handle3);
34         handle1.handleRequest();
35     }
36 }

  运行结果

getSuccessor !
getSuccessor !
handle in this! request()!

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

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 【java开发系列】—— 自定义注解

      之前在开发中,就总纳闷,为什么继承接口时,会出现@Override注解,有时候还会提示写注解@SuppressWarnings?   原来这是java特有...

    用户1154259
  • Java程序员的日常—— 垃圾回收中引用类型的作用

    在Java里面,是不需要太过于关乎垃圾回收,但是这并不意味着开发者可以不了解垃圾回收的机制,况且在java中内存泄露也是家常便饭的事情。因此了解垃圾回收的相关...

    用户1154259
  • 【设计模式】—— 备忘录模式Memento

      模式意图   这个模式主要是想通过一个对象来记录对象的某种状态,这样有利于在其他需要的场合进行恢复。   该模式还有跟多可以扩展的地方,比如可以记录多个时...

    用户1154259
  • 设计模式——责任链

     假设有一个论坛,很多人可以在上面发消息,但是这些消息,有的需要过滤敏感字眼,有的又需要修改关键字,举个简单的例子

    mathor
  • vue项目iframe的传值问题

      所以。我把插件的使用封装了一个html页面。vue项目则利用iframe的方式引入。

    Dawnzhang
  • shell入门系列(9)grep

    [外链图片转存失败(img-Us3HVPA2-1563242272153)(http://ww1.sinaimg.cn/large/006jIRTegy1fzd...

    suveng
  • Kafka 自定义序列化器和反序列化器

    现 Kafka Producer 需要把 Customer 类的对象序列化成字节数组发送给 Kafka Broker,同时 Kafka Consumer 需要把...

    CoderJed
  • Jewel版本Ceph集群功能性能测试

    http://docs.ceph.com/docs/master/start/quick-start-preflight/#rhel-centos https:...

    三杯水Plus
  • 秒杀Deepfake!微软北大提出AI换脸工具FaceShifter和假脸检测工具Face X-Ray

    最先进的AI和机器学习算法不仅可以生成栩栩如生的位置和物体的图像,还擅长将人脸头像从一个人换成另一个人的。另一方面,研究人员也在不断开发能够检测deepfake...

    新智元
  • 常见Java面试题 – 第四部分:迭代(iteration)和递归(recursion)

    A. 可重入方法(re-entrant method)是可以安全进入的方法,即使同一个方法正在被执行,深入到同一个线程的调用栈里面也不会影响此次执行的安全性。一...

    哲洛不闹

扫码关注云+社区

领取腾讯云代金券