当前位置: 首页 > article >正文

【软考】设计模式之责任链模式

目录

          • 1. 说明
          • 2. 应用场景
          • 3. 结构图
          • 4. 构成
          • 5. 适用性
          • 6. 优点
          • 7. 缺点
          • 8. java示例

1. 说明
  • 1.使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。
  • 2.将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止。
  • 3.责任链模式(Chain of Responsibility Pattern)是一种行为设计模式。
  • 4.它为请求的发送者和接收者之间解耦提供了一种相对松散的耦合方式,使得多个对象都有机会处理这个请求,或者将这个请求传递给链中的下一个对象。
  • 5.这种模式将多个处理者对象连成一条链,并沿着这条链传递请求,直到有一个对象处理它为止。
  • 6.这种模式给予请求传递的灵活性,并且使得对象不需要知道链的结构。
2. 应用场景
  • 1.多个对象可以处理一个请求,但具体由哪个对象处理在运行时决定。
  • 2.在不明确指定接收者的情况下,向多个对象中的一个提交一个请求。
  • 3.可动态指定一组对象处理请求。
3. 结构图

在这里插入图片描述

4. 构成
  • 1.抽象处理者(Handler):定义一个处理请求的接口,通常包含一个或多个指向下一个处理者的引用(即链中的下一个节点)和一个处理请求的接口方法。(可选)实现后继链。
  • 2.具体处理者(Concrete Handler):实现了抽象处理者角色定义的接口,主要负责处理它负责的请求,或者将请求转发给链中的下一个处理者,以及可以访问链中下一个处理者的引用。处理它所负责的请求;可访问它的后继者;如果可处理该请求,就处理它,否则将该请求转发给后继者。
  • 3.客户端(Client):创建处理链,并向链中的第一个处理者对象提交请求。向链上的具体处理者(ConcreteHandler)对象提交请求。
5. 适用性
  • 1.有多个的对象可以处理一个请求,哪个对象处理该请求运行时刻自动确定。
  • 2.想在不明确指定接收者的情况下向多个对象中的一个提交一个请求。
  • 3.可处理一个请求的对象集合应被动态指定。
6. 优点
  • 1.降低耦合度:将请求的发送者和接收者解耦。
  • 2.简化对象:使得对象不需要知道链的结构。
  • 3.增强给请求分配职责的灵活性:通过改变链内的成员或调动它们的次序,允许动态地新增或者删除处理者。
  • 4.增加新的处理类很容易:无须修改现有代码,符合开闭原则。
7. 缺点
  • 1.不能保证请求一定被处理:如果没有处理者处理该请求,请求就会一直传递下去,直到链的末尾。
  • 2.系统性能会受到一定影响:因为请求在链中传递,每个处理者都需要对请求进行判断,增加了系统响应时间。
  • 3.调试复杂:链中处理者众多,增加了系统复杂性,可能难以追踪和调试。
8. java示例
  • 1.日志处理器接口
package com.learning.responsibility.example;

// 日志处理器接口
public interface Logger {  
    void log(LogMessage message);  
    void setNextLogger(Logger nextLogger);  
} 
  • 2.日志级别枚举
package com.learning.responsibility.example;

// 日志级别枚举
public enum LogLevel {  
    INFO, DEBUG, ERROR  
} 
  • 3.日志消息类
package com.learning.responsibility.example;

// 日志消息类
public class LogMessage {  
    private LogLevel level;  
    private String message;  
  
    public LogMessage(LogLevel level, String message) {  
        this.level = level;  
        this.message = message;  
    }  
  
    public LogLevel getLevel() {  
        return level;  
    }  
  
    public String getMessage() {  
        return message;  
    }  
}
  • 4.抽象日志处理器类
package com.learning.responsibility.example;

// 抽象日志处理器类
public abstract class AbstractLogger implements Logger {  
    protected int level;  
    protected Logger nextLogger;  
  
    @Override
    public void setNextLogger(Logger nextLogger) {
        this.nextLogger = nextLogger;  
    }  
  
    protected void writeToLog(String message) {  
        System.out.println("日志级别:" + level + ", 日志内容:" + message);
    }  
  
    @Override  
    public void log(LogMessage message) {  
        if (this.level <= message.getLevel().ordinal()) {  
            write(message);  
        }  
        if (nextLogger != null) {  
            nextLogger.log(message);  
        }  
    }  
  
    abstract protected void write(LogMessage message);  
}
  • 5.INFO日志处理器
package com.learning.responsibility.example;

// INFO日志处理器
public class InfoLogger extends AbstractLogger {  
    public InfoLogger(int level) {  
        this.level = level;  
    }  
  
    @Override  
    protected void write(LogMessage message) {  
        if (message.getLevel() == LogLevel.INFO) {  
            writeToLog(message.getMessage());  
        }  
    }  
} 
  • 6.DEBUG日志处理器
package com.learning.responsibility.example;

// DEBUG日志处理器
public class DebugLogger extends AbstractLogger {  
    public DebugLogger(int level) {  
        this.level = level;  
    }  
  
    @Override  
    protected void write(LogMessage message) {  
        if (message.getLevel() == LogLevel.DEBUG) {  
            writeToLog(message.getMessage());  
        }  
    }  
}  
  • 7.ERROR日志处理器
package com.learning.responsibility.example;

// ERROR日志处理器
public class ErrorLogger extends AbstractLogger {  
    public ErrorLogger(int level) {  
        this.level = level;  
    }  
  
    @Override  
    protected void write(LogMessage message) {  
        if (message.getLevel() == LogLevel.ERROR) {  
            writeToLog(message.getMessage());  
        }  
    }  
}
  • 8.应用类
package com.learning.responsibility.example;

public class Client {
    public static void main(String[] args) {
        Logger loggerChain = null; // 创建日志处理器链
        Logger infoLogger = new InfoLogger(LogLevel.INFO.ordinal());
        Logger debugLogger = new DebugLogger(LogLevel.DEBUG.ordinal());
        Logger errorLogger = new ErrorLogger(LogLevel.ERROR.ordinal());

        // 设置链
        infoLogger.setNextLogger(debugLogger);
        debugLogger.setNextLogger(errorLogger);

        loggerChain = infoLogger;

        // 发送日志消息
        loggerChain.log(new LogMessage(LogLevel.INFO, "info级别日志"));
        loggerChain.log(new LogMessage(LogLevel.DEBUG, "debug级别日志"));
        loggerChain.log(new LogMessage(LogLevel.ERROR, "error级别日志"));
    }
}
  • 9.示例截图
    在这里插入图片描述

http://www.kler.cn/a/303865.html

相关文章:

  • 信息系统项目管理-采购管理-采购清单示例
  • 【钉钉在线笔试题】字符串表达式的加减法
  • leetcode 面试经典 150 题:两数之和
  • GPU算力平台|在GPU算力平台部署Qwen-2通义千问大模型的教程
  • 《零基础Go语言算法实战》【题目 1-14】字符串的替换
  • Ubuntu上安装Apache Spark
  • springboot对数据库进行备份+对一个文件夹内的文件按时间排序,只保留最近的8个文件
  • 基于鸿蒙API10的RTSP播放器(四:沉浸式播放窗口)
  • 五星级可视化页面(23):污水处理、防汛可视化大屏
  • 自闭症摘帽流程解析:从诊断到摘帽的完整指南
  • graphQL 参数使用报错问题
  • Node.js学习记录(二)
  • 鸿蒙(API 12 Beta6版)GPU加速引擎服务【自适应VRS】
  • C语言 条件编译
  • 【2024】前端学习笔记5-表单标签使用
  • leaflet【十】实时增加轨迹点轨迹回放效果实现
  • 2024/9/11学校教的响应式前端能学到什么?
  • 【路径规划】APF算法、Vortex APF算法、Safe APF算法和动态Windows方法的比较
  • AI教你学Python 第3天:函数和模块
  • ai智能语电销机器人有哪些功能?
  • 初识软件测试
  • 数据结构——单链表基本操作的实现
  • 我与Linux的爱恋:自动化构建工具-make/Makefile
  • 测试-Gatling 与性能测试
  • 98、RS485全自动收发电路入坑笔记
  • Gmtracker_深度学习驱动的图匹配多目标跟踪项目启动与算法流程