定义
责任链模式(Chain of Responsibility Pattern):避免请求发送者与接收者耦合在一起,让多个对象都有可能接收请求,将这些对象连接成一条链,并且沿着这条链传递请求,直到有对象处理它为止。职责链模式是一种对象行为型模式。
从定义可以看出,责任链模式将请求发送者和处理者解偶,即发送方不用知道谁来处理他的请求(没有类依赖),同时集中的处理者结构允许多个处理者共享请求和分布处理,很像流水线加工厂的方式。所以责任链模式常常用在过滤器设计,触摸事件处理等场景中。
Handler(抽象处理者):它定义了一个处理请求的接口,一般设计为抽象类,由于不同的具体处理者处理请求的方式不同,因此在其中定义了抽象请求处理方法。抽象处理者需要做两件事,其一是定义处理接口,二是定义责任链的链接方式,比如如果处理者之间存在链表或者树状关系,则采用链表形式,需要在抽象处理者中保留下一个处理者的引用;如果处理者之间彼此逻辑独立,则可以采用数组来维持链状结构。
ConcreteHandler(具体处理者):它是抽象处理者的子类,可以处理用户请求。具体处理者也需要做两件事,其一是实现自己的处理逻辑,二是表明自己的处理权限。
代码
public abstract class IRequestHandler {
public abstract boolean handler(Request request);
}
public class HttpOriginDataIntercept extends IRequestHandler {
@Override
public boolean handler(Request request) {
if (!request.mBaseUrl.startsWith("https")) {
return false;
}
return true;
}
}
public class ContentCheckHander extends IRequestHandler {
@Override
public boolean handler(Request request) {
return !request.mContent.contains("黄赌毒");
}
}
public class RequestHandlerContainer extends IRequestHandler {
List<IRequestHandler> handlers = new ArrayList<>();
public RequestHandlerContainer addHandler(IRequestHandler handler){
handlers.add(handler);
return this;
}
@Override
public boolean handler(Request request) {
for (IRequestHandler handler:
handlers) {
if (!handler.handler(request)) {
return false;
}
}
return true;
}
}
public class Request {
String mBaseUrl;
HashMap<String, String> mHeader;
String mContent;
}
上述代码中简单描述一个请求的检查过程,提供了请求的协议检查和内容检查,其检查链上可以动态增加和删除检查实现,这里检查链采用了集合来构建,因为多个检查标准没有逻辑关系,这个和Arouter中的过滤器很相似。而像Android中的view的事件分发和处理这种是采用了类的关联来构建事件处理链。
总结
职责链模式的主要优点
- 对象仅需知道该请求会被处理即可,且链中的对象不需要知道链的结构,由客户端负责链的创建,降低了系统的耦合度
- 请求处理对象仅需维持一个指向其后继者的引用,而不需要维持它对所有的候选处理者的引用,可简化对象的相互连接
- 在给对象分派职责时,职责链可以给我们更多的灵活性,可以在运行时对该链进行动态的增删改,改变处理一个请求的职责
- 新增一个新的具体请求处理者时无须修改原有代码,只需要在客户端重新建链即可,符合 "开闭原则"
职责链模式的主要缺点
- 一个请求可能因职责链没有被正确配置而得不到处理
- 对于比较长的职责链,请求的处理可能涉及到多个处理对象,系统性能将受到一定影响,且不方便调试
- 可能因为职责链创建不当,造成循环调用,导致系统陷入死循环