装饰器模式和责任链模式区别

目录

装饰器模式

特点

使用场景

编码形式

使用案例

责任链模式

特点

使用场景

编码形式

使用案例


近期看了 mybatis 的源码,发现二级缓存这块用了装饰器模式将各个功能的缓存进行嵌套,源码上也是讲到使用了装饰器模式,但是看着跟责任链模式类似,本着搞清楚的想法,搜了很多资料,看了书籍《Head First 设计模式》上对于装饰器模式和责任链模式的讲解,思考如下

装饰器模式

特点

通过委托来实现(一般是定义了一个 delegate 变量来引用定义的操作的接口),流程中的各个节点都参与了处理,运行时动态处理。

使用场景

适用于灵活变动需要组合处理的情况,即协作处理,各个节点无阻塞,直到执行到最底层的节点,需要反馈会逆序返回。

编码形式

简单,对于执行的操作只需要调用一次即可,各个具体装饰类实现会链式调用委托对象的方法进行处理。

使用案例

spring 中的 aop 实现的事务管理和日志管理。

书籍《Head First 设计模式》上对于装饰器模式用了一个饮料加配料的例子来讲解这个问题。

责任链模式

特点

各个节点经过了流转,但是不一定进行了处理(能处理就处理,不能处理就走过场转交给别人),即使处理了不一定有结果。自己处理不了的交给别人。

使用场景

适用于对于某些操作可能指定了一系列操作步骤(例如审批),各个步骤都需要执行。

编码形式

麻烦,对于执行的操作每个过程需要编码实现。

使用案例

工作流审批

javaee 中的 filter chain

参考链接

https://blog.csdn.net/qq_42449106/article/details/131542919

https://blog.csdn.net/jiadajing267/article/details/106889562

https://www.cnblogs.com/darope/p/12695256.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值