Day40 【概念解析】责任链模式
目录 ▼
整理定义
中文名称:责任链模式/职责链模式
英文名称:chain of responsibility pattern/CoR/Chain of Command
复述展开
What is chain of responsibility pattern?
📌 责任链模式是一种行为设计模式。它把可以响应对象组成形成一条链条,使得请求发送时,每个处理者都可以对请求进行处理,或是直接传给下个处理者。这种模式使得系统可以在不影响客户端的情况下动态地重新组织和分配责任。
责任链模式结构

-
处理者 (Handler) 声明了所有具体处理者的通用接口。 该接口通常仅包含单个方法用于请求处理, 但有时其还会包含一个设置链上下个处理者的方法。
-
基础处理者 (Base Handler) 是一个可选的类, 你可以将所有处理者共用的样本代码放置在其中。
-
具体处理者 (Concrete Handlers) 包含处理请求的实际代码。 每个处理者接收到请求后, 都必须决定是否进行处理, 以及是否沿着链传递请求。
-
客户端 (Client) 可根据程序逻辑一次性或者动态地生成链。 值得注意的是, 请求可发送给链上的任意一个处理者, 而非必须是第一个处理者。
使用场景
🌰 当程序需要使用不同方式处理不同种类请求, 而且请求类型和顺序预先未知时, 可以使用责任链模式。
该模式能将多个处理者连接成一条链。 接收到请求后, 它会 “询问” 每个处理者是否能够对其进行处理。 这样所有处理者都有机会来处理请求。
🌰 当必须按顺序执行多个处理者时, 可以使用该模式。
无论你以何种顺序将处理者连接成一条链, 所有请求都会严格按照顺序通过链上的处理者。
🌰 如果所需处理者及其顺序必须在运行时进行改变, 可以使用责任链模式。
如果在处理者类中有对引用成员变量的设定方法, 你将能动态地插入和移除处理者, 或者改变其顺序。
优缺点
优点:
-
你可以控制请求处理的顺序。
-
单一职责原则。 你可对发起操作和执行操作的类进行解耦。
-
开闭原则。 你可以在不更改现有代码的情况下在程序中新增处理者。
缺点:
- 部分请求可能未被处理。
理解体会
责任链的使用场景还是比较多的:
-
多条件流程判断:权限控制
-
ERP 系统流程审批:总经理、人事经理、项目经理
-
Java 过滤器的底层实现 Filter