职责链模式
基本介绍
- 职责链模式(Chain of Responsibility)又叫责任链模式,为请求创建一个接收者对象的链,这种模式对请求的发送者和接收者进行解耦
- 职责链模式通常每个接收者都包含对另一个接收者的引用。如果一个对象不能处理该请求,那么它会把相同的请求传给下一个接收者,依次类推
- 那种设计模式属于行为型模式
原理说明
- Handler: 抽象的处理者,定义了一个处理请求的接口,同时含有另外一个Handler对象
- ConcreteHandler:具体的处理者,处理自己负责的请求,可以访问它的后继者,即下一个处理者,如果自己可以处理当前请求,则处理,否则,将请求传递给后继者,从而形成职责链
- Request:含有很多属性,表示一个请求
注意事项和细节
- 将请求和处理分开,实现解耦,提高系统的灵活性
- 简化了对象,使对象不需要知道链的结构
- 性能会受到影响,特别是在链比较长的时候,因此需控制链中最大节点数量,一般通过在handler中设置一个最大节点数量,在setNext方法中判断是否已经超过了阈值,超过则不允许该链建立,避免出现超长链无意识的破坏系统性能
- 调试不方便,采用了类似递归的方式,调试时逻辑可能比较复杂
- 最佳应用场景:有多个对象可以处理同一个请求,比如:多级请求、请假、加薪、等审批流程,Java Web中Tomcat对Encoding的处理、拦截器