二十三种设计模式第十八篇--责任链模式

责任链模式是一种行为型设计模式,它允许你将请求沿着处理者链传递,直到有一个处理者能够处理该请求为止。责任链模式将请求发送者和请求处理者解耦,从而使得多个处理者都有机会处理同一个请求。

该模式包含以下几个关键角色:

抽象处理者(Handler):定义了一个处理请求的接口,并指定下一个处理者的引用。

具体处理者(ConcreteHandler):实现抽象处理者接口,具体处理请求的逻辑。如果当前处理者能够处理该请求,则处理之;否则,将请求传递给下一个处理者。

客户端(Client):创建处理者链,并向链上的第一个处理者发送请求。

责任链模式的核心思想是将请求发送者与请求处理者解耦,并将其组织成一个链条当有新的请求发送时,责任链上的处理者依次进行判断,如果当前处理者能够处理该请求,则处理之;否则,将请求传递给下一个处理者。这样可以实现请求的动态分发和处理,而无需显式指定处理者。

责任链模式适用于以下场景:

  1. 存在多个对象可以处理同一种类型的请求,并且希望请求在运行时自动确定最终处理者。
  2. 需要避免请求发送者和接收者之间的耦合关系,以便于灵活地组织和配置处理者链。
  3. 希望动态地增加或者删除处理者,而无需对客户端代码进行修改。
java 复制代码
public abstract class AbstractLogger {
   public static int INFO = 1;
   public static int DEBUG = 2;
   public static int ERROR = 3;

   /**
    *    当前logger的级别: 只有要输出 的信息的级别中于等于level时,当前这个logger才能处理 write()
    *          如果大于此level, 就要通过职责链,去查看是否有更高级别的logger.
    */
   protected int level;  // 1
 
   //责任链中的下一个元素
   protected AbstractLogger nextLogger;
 
   public void setNextLogger(AbstractLogger nextLogger){
      this.nextLogger = nextLogger;
   }

   /**
    *
    * @param level: 信息的级别
    * @param message: 日志信息
    */
   public void logMessage(int level, String message){
      if(this.level <= level){
         write(message);
      }
      //如果message的级别level高于当前这个logger对应的级别,则交给它的下一级进行处理》
      if(nextLogger !=null){
         nextLogger.logMessage(level, message);
      }
   }
 
   abstract protected void write(String message);
   
}
java 复制代码
public class ChainPatternDemo {

   /**
    * 组装责任链
    * @return
    */
   private static AbstractLogger getChainOfLoggers(){
      //创建日志器,并指定每个日志器的能处理级别
      AbstractLogger errorLogger = new ErrorLogger(AbstractLogger.ERROR);
      AbstractLogger debugLogger = new FileLogger(AbstractLogger.DEBUG);
      AbstractLogger infoLogger = new ConsoleLogger(AbstractLogger.INFO);
      //组装职责链
      // error 3> debug 2> info 1
      errorLogger.setNextLogger(debugLogger);
      debugLogger.setNextLogger(infoLogger);
      return errorLogger;   //3
   }
 
   public static void main(String[] args) {
      //获取日志职责链
      AbstractLogger loggerChain = getChainOfLoggers();

      //                                  1
     // loggerChain.logMessage(AbstractLogger.INFO, "This is an information.");
 
   loggerChain.logMessage(AbstractLogger.DEBUG, "This is a debug level information.");
 
    //  loggerChain.logMessage(AbstractLogger.ERROR, "This is an error information.");
   }
}
java 复制代码
public class ConsoleLogger extends AbstractLogger {
 
   public ConsoleLogger(int level){
      this.level = level;
   }
 
   @Override
   protected void write(String message) {    

      System.out.println("Standard Console::Logger: " + message);
   }
}
java 复制代码
public class ErrorLogger extends AbstractLogger {
 
   public ErrorLogger(int level){
      this.level = level;
   }
 
   @Override
   protected void write(String message) {    
      System.out.println("Error Logger: " + message);
   }
}
java 复制代码
public class FileLogger extends AbstractLogger {
 
   public FileLogger(int level){
      this.level = level;
   }
 
   @Override
   protected void write(String message) {    
      System.out.println("File::Logger: " + message);
   }
}

总之,责任链模式适用于请求的发送者和接收者之间存在耦合关系的情况,以及需要在运行时动态确定最终处理者的情况。它能够提高代码的灵活性、可扩展性和可维护性,使得处理请求的过程变得灵活和可配置。

每一天都是一个新的机会,你可以选择哪一种心态去迎接它。选择积极的心态,相信自己的能力,勇敢面对挑战,你就会发现无所不能的力量在你身上。相信自己,相信未来,勇往直前,你一定能够创造属于自己的辉煌。

相关推荐
风铃儿~18 分钟前
Spring AI 入门:Java 开发者的生成式 AI 实践之路
java·人工智能·spring
斯普信专业组23 分钟前
Tomcat全方位监控实施方案指南
java·tomcat
忆雾屿34 分钟前
云原生时代 Kafka 深度实践:06原理剖析与源码解读
java·后端·云原生·kafka
武昌库里写JAVA1 小时前
iview Switch Tabs TabPane 使用提示Maximum call stack size exceeded堆栈溢出
java·开发语言·spring boot·学习·课程设计
gaoliheng0061 小时前
Redis看门狗机制
java·数据库·redis
我是唐青枫1 小时前
.NET AOT 详解
java·服务器·.net
Su米苏1 小时前
Axios请求超时重发机制
java
本郡主是喵3 小时前
并发编程 - go版
java·服务器·开发语言
南风lof3 小时前
源码赏析:Java线程池中的那些细节
java·源码阅读