chain of responsibility模式
场景:
- 现在在某一个地方的业务流程,要执行功能1、功能2、功能3
- 现在在另外一个地方的业务流程,是要先执行功能3,然后执行功能1和功能2
责任链模式,那也是经常会使用到的,对于那种复杂的业务流程,一种方案是采取面向对象的设计,将不同的业务逻辑封装到不同的类里去,然后通通过方法中的调用来控制业务流向;另外一种就是采用责任链模式,将业务逻辑封装到不同的 handler 里面去,形成链条式调用。
什么时候用责任链模式呢?很简单,就是如果你需要动态组装一个业务流程出来,流程中的每个 handler 业务逻辑需要复用,那就用责任链模式。
package com.example.designpattern.chain;
public class ChainPatternDemo {
public static void main(String[] args) {
// 业务流程1
Handler thirdHandler = new Handler3(null);
Handler secondHandler = new Handler2(thirdHandler);
Handler firstHandler = new Handler1(secondHandler);
firstHandler.execute();
// 业务流程2
thirdHandler = new Handler3(null);
secondHandler = new Handler1(thirdHandler);
firstHandler = new Handler2(secondHandler);
firstHandler.execute();
// 责任链的思想
// 1:将一个业务流程中的多个步骤拆分开来,每个步骤封装到一个handler处理器中去
// 2:支持业务流程基于handler动态组装,不同的业务流程 -> handler代表的代码组件可以复用
// 好处1:将这个代码封装到一个handler中,后面如果要对某个步骤的代码逻辑调整,修改一个handler即可
// 好处2:如果业务流程要修改,那么不需要拷贝大量的代码,只要基于handler动态组装业务流程即可
// 面向的场景
// 就是有多个业务流程,这些业务流程之间有相同的代码逻辑和步骤
// 可以用责任链模式来实现
}
public static abstract class Handler{
protected Handler successor;
public Handler(Handler successor){
this.successor = successor;
}
public abstract void execute();
}
public static class Handler1 extends Handler {
public Handler1(Handler successor) {
super(successor);
}
public void execute() {
System.out.println("执行功能1");
if(successor!=null){
successor.execute();
}
}
}
public static class Handler2 extends Handler {
public Handler2(Handler successor) {
super(successor);
}
public void execute() {
System.out.println("执行功能2");
if(successor != null) {
successor.execute();
}
}
}
public static class Handler3 extends Handler {
public Handler3(Handler successor) {
super(successor);
}
public void execute() {
System.out.println("执行功能3");
if(successor != null) {
successor.execute();
}
}
}
}