二十三种设计模式全面解析-职责链模式的高级应用-日志记录系统


在软件开发领域,职责链模式(Chain of Responsibility Pattern)是一种强大而灵活的设计模式,它能够将请求的发送者和接收者解耦,提高代码的灵活性和可维护性。本文将深入探讨职责链模式的优点和缺点,并提供更多实际应用案例,帮助你更好地理解和应用这一设计模式。


一、职责链模式优点

  1. 解耦责任:职责链模式将请求发送者和接收者解耦,每个处理者对象只需关注自己应该处理的请求,无需了解整个处理流程。这样可以使系统更加灵活,方便增加、删除或重新排序处理者对象。

  2. 增强可扩展性:由于职责链模式允许动态地添加新的处理者对象或调整处理顺序,因此非常适用于需求频繁变化的场景。新的处理者对象可以根据需要随时插入到职责链中,而无需修改现有代码。

  3. 简化对象:职责链模式将责任分散到多个对象中,每个对象只需关注自己的责任范围,代码结构更加清晰简洁。


二、职责链模式缺点

  1. 请求未被处理:在职责链模式中,如果没有合适的处理者对象能够处理请求,可能会导致请求无法被处理。这种情况下,请求可能会被忽略或者没有得到及时处理,需要在设计时注意处理者对象的覆盖范围。

  2. 对性能的影响:由于职责链中的每个处理者对象都可能处理请求,因此可能会导致请求经过多次传递和判断,对性能造成一定的影响。在设计时需要优化职责链的结构,避免过多的传递和判断操作。


三、实际应用案例-日志记录系统

职责链模式可以用于日志记录系统中的日志处理链。每个处理者对象可以负责不同级别的日志记录,比如Debug、Info、Warning和Error。请求将依次经过处理者对象,根据日志级别进行处理和记录。

abstract class Handler {protected Handler nextHandler;public void setNextHandler(Handler nextHandler) {this.nextHandler = nextHandler;}public abstract void logMessage(String message, int level);
}

然后,我们创建具体的处理者类,分别处理不同级别的日志记录请求:

class InfoLogger extends Handler {public void logMessage(String message, int level) {if (level == 1) {System.out.println("InfoLogger: " + message);} else if (nextHandler != null) {nextHandler.logMessage(message, level);}}
}class WarningLogger extends Handler {public void logMessage(String message, int level) {if (level == 2) {System.out.println("WarningLogger: " + message);} else if (nextHandler != null) {nextHandler.logMessage(message, level);}}
}class ErrorLogger extends Handler {public void logMessage(String message, int level) {if (level == 3) {System.out.println("ErrorLogger: " + message);} else if (nextHandler != null) {nextHandler.logMessage(message, level);}}
}

最后,我们在客户端代码中创建处理者对象,并将它们连接成一个职责链:

public class Main {public static void main(String[] args) {Handler infoLogger = new InfoLogger();Handler warningLogger = new WarningLogger();Handler errorLogger = new ErrorLogger();infoLogger.setNextHandler(warningLogger);warningLogger.setNextHandler(errorLogger);// 模拟不同级别的日志记录请求infoLogger.logMessage("This is an informational message.", 1);infoLogger.logMessage("This is a warning message.", 2);infoLogger.logMessage("This is an error message.", 3);}
}

在这个案例中,我们创建了三个具体的处理者对象:InfoLogger、WarningLogger和ErrorLogger,它们分别处理级别为1、2和3的日志记录请求。我们通过调用setNextHandler()方法将处理者对象连接成一个职责链,然后通过调用logMessage()方法来处理日志记录请求。请求将依次经过处理者对象,直到找到能够处理请求的处理者对象或者达到职责链的末尾。


以上就是使用职责链模式实现日志记录系统的简单示例。通过这种方式,我们可以根据日志级别将日志请求动态分发给不同的处理者对象,并实现灵活的日志记录功能。


在下一篇文章中,我们将进一步探讨职责链模式的高级应用,敬请期待!


好了,今天的分享到此结束。如果觉得我的博文帮到了您,您的点赞和关注是对我最大的支持。如遇到什么问题,可评论区留言。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/151151.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习Opencv(蝴蝶书/C++)代码——2.OpenCV初探

文章目录 0. 图像读取与显示1. 视频文件读取与操作1.1 示例代码1.1 OpenCV支持的视频格式2. 加入滑动条2.1 示例代码2.2 报错/Warning2.3 关于toolbar3. 简易视频播放器3.1 OpenCV检测方向键被按下3.1.1 Windows下3.1.2 linux下3.1 方向键控制视频变化4. 简单的变换5. 写视频5.…

三相异步电机动态数学模型及矢量控制仿真

文章目录 三相异步电机动态数学模型及矢量控制仿真1、异步电机三相方程2、坐标变换3、磁链3/2变换推导4、两相静止坐标系下的方程5、两相旋转坐标系下的方程6、以 ω-is-Ψr 为状态变量的状态方程7、矢量控制及 matlab 仿真 原文链接需要仿真的同学请关注【Qin的学习营地】 三相…

JMeter基础

JMeter工具基础使用 JMeter的三个重要组件线程组HTTP请求查看结果树 JMeter参数化用户定义的变量用户参数CSV数据文件设置函数四种参数化方式的不同 JMeter断言JMeter关联正则表达式XPath提取器JSON提取器 JMeter属性JMeter录制脚本JMeter直连数据库JMeter逻辑控制器JMeter定时…

百云齐鲁 | 云轴科技ZStack成功实践精选(山东)

山东省作为我国重要的工业基地和北方地区经济发展的战略支点,在“十四五”规划中将数字强省建设分为数字基础设施、数字科技、数字经济、数字政府、数字社会、数字生态六大部分,涵盖政治、经济、民生等多个方面,并将大数据、云计算、人工智能…

【错误记录】Uncaught TypeError: m.nodeName.toLowerCase is not a function

描述:在控制台输出上述错误~ 原因:在页面中,使用jQuery 开发时,命名不能和jQuery一起方法属性冲突,比如这里的nodeName,这里换一个不冲突的名字,就解决问题了。

统一身份认证平台之SSO建设

前言 上篇说道Passwordless无密码技术,也提到了数字时代密码管理的难度,其实在日常的生活中,很多用户也会因为忘记某些网站的登录密码而烦恼。为了方便记忆,很多人都在不同的站点使用相同的用户名和密码,虽然也可以减少…

uvm环境获取系统时间的方法和使用案例

背景: 有时候我们想统计一下验证环境中某个步骤总共花费了多少时间,有什么比较方便的方法呢,利用$realtime理论上也是能做到的,不过这个和timescale绑定起来了,需要手动换算成单位是秒的数,现在提供一种利用…

未来之路:互联网技术驱动汽车行业的创新浪潮

在互联网迅猛发展的今天,它的触角已延伸至各行各业,其中最引人注目的莫过于汽车行业。随着互联网技术的融合,汽车正变得越来越智能,预示着一场关于出行方式的革命。 首先,自动驾驶技术的发展正日益成熟。依托先进的传感…

josef约瑟 闭锁继电器 LB-7DG 100V 50HZ 导轨安装

LB-7型闭锁继电器 闭锁继电器LB-7导轨安装 一、用途 LB-7型闭锁继电器(以下简称继电器)用于发电厂及变电所内高压母线带电时防止和接地刀闸。 二、结构和工作原理 1、继电器按整流式原理构成,该继电器由变压器、电阻器、整流桥、滤波电容、极化继电器及指示灯组…

新人报到

文章目录 自我介绍博客平台写一些什么?为什么写博客? 自我介绍 计算机硕士研究生在读(研二),研究方向为神经网络模型量化、模型部署、深度学习和计算机视觉等。 博客平台 CSDN:_leoatliang 2022年5月12…

【C++初阶】STL详解(四)vector的模拟实现

本专栏内容为:C学习专栏,分为初阶和进阶两部分。 通过本专栏的深入学习,你可以了解并掌握C。 💓博主csdn个人主页:小小unicorn ⏩专栏分类:C 🚚代码仓库:小小unicorn的代码仓库&…

Looking up a deactivated widget‘s ancestor is unsafe

背景: showCupertinoModalPopup中使用Navigator.of(context).pushNamedAndRemoveUntil(RouteName.login, (route) > false); 报错:Looking up a deactivated widget’s ancestor is unsafe 解决方案:先将CupertinoModal关闭,再…

使用Lychee搭建个人图片存储系统并进行远程访问设置实现公网访问本地私人图床

文章目录 1.前言2. Lychee网站搭建2.1. Lychee下载和安装2.2 Lychee网页测试2.3 cpolar的安装和注册 3.本地网页发布3.1 Cpolar云端设置3.2 Cpolar本地设置 4.公网访问测试5.结语 1.前言 图床作为图片集中存放的服务网站,可以看做是云存储的一部分,既可…

esbuild打包

esbuild官网 npm install esbuild此命令应该会将 esbuild 安装到你本地的 node_modules 中。 你可以运行如下命令,来检测 esbuild 的原生可执行文件 是否正常: .\node_modules\.bin\esbuild --version这是一个简易的真实案例,用于说明 esbu…

为什么大家考完软考中级都去考高级?原因在这里!

2023上半年软考考试已经结束了,有很多同学在后台留言,一起考软考中级的同学都开始备考高级了,为什么考完软考中级还要考高级呢?软考高级含金量大吗?考试难度高吗?软考中级我考的集成,高级应该选…

STM32获取最大堆栈空间

参考 stackflow相关讨论 原理 通过参考链接,可知探测Stack的最大深度是先在stack中填充不常用的特定值,然后实时检测这些值哪些发生了变化,变化的表示使用到了这个空间,如果程序完全遍历后,有些值还是没变&#xff…

c语言-输入输出详解

文章目录 格式化输入输出占位符printfscanf 字符串输入输出puts&#xff08;&#xff09;gets&#xff08;&#xff09; 字符输入输出putchar&#xff08;&#xff09;getchar&#xff08;&#xff09; 区别 格式化输入输出 输入输出的库函数的头文件&#xff1a; #include<…

物联网AI MicroPython学习之语法 SPI串行外设通信

学物联网&#xff0c;来万物简单IoT物联网&#xff01;&#xff01; SPI 介绍 模块功能: SPI串行外设驱动 接口说明 SPI - 构建SPI对象 函数原型&#xff1a;SPI(id, baudrate&#xff0c;polarity, phase&#xff0c;sck, mosi, miso)参数说明&#xff1a; 参数类型必选参…

内置函数和消息传递API

消息传递范式 消息函数、聚合函数与更新函数 消息函数接受一个参数 edges&#xff0c;这是一个 EdgeBatch 的实例&#xff0c; 在消息传递时&#xff0c;它被DGL在内部生成以表示一批边。edges 有 src、 dst 和 data 共3个成员属性&#xff0c; 分别用于访问源节点、目标节点…

使用Docker/K8S/Helm部署项目流程

假设项目已经开发完成&#xff0c;部署流程如下&#xff1a; 一、制作镜像&#xff1a; 1、创建nginx配置文件default.conf server {listen 80;server_name localhost; # 修改为docker服务宿主机的iplocation / {root /usr/share/nginx/html;index index.html ind…