设计模式(十)_责任链模式

简介: 概述责任链模式为某个请求创建一个对象链,每个对象依次检查此请求,并对其进行处理,或者将它传给链中的下一个对象UML类图代码实现handle类package com.zhb.proxy_demo.

概述

责任链模式为某个请求创建一个对象链,每个对象依次检查此请求,并对其进行处理,或者将它传给链中的下一个对象

UML类图

img_a3edf4a5863551e8a5cb4f3c289b70ec.png

代码实现

handle类

package com.zhb.proxy_demo.chain;

/**
 * @author: curry
 * @Date: 2018/7/30
 */
public abstract class Handler {

    private Handler sucessor;

    public Handler getSucessor() {
        return sucessor;
    }

    public void setSucessor(Handler sucessor) {
        this.sucessor = sucessor;
    }

    public void execute(){
        handleProcess();
        if(sucessor != null){
            sucessor.execute();
        }
    }

    /**
     * 交给子类实现
     */
    protected abstract void handleProcess();
}

Client类

package com.zhb.proxy_demo.chain;

/**
 * @author: curry
 * @Date: 2018/7/30
 */
public class Client {

    static class HandleA extends Handler {

        @Override
        protected void handleProcess() {
            System.out.println("handle by A");
        }
    }

    static class HandleB extends Handler {

        @Override
        protected void handleProcess() {
            System.out.println("handle by B");
        }
    }

    static class HandleC extends Handler {

        @Override
        protected void handleProcess() {
            System.out.println("handle by C");
        }
    }

    public static void main(String[] args) {
        Handler handlerA = new HandleA();
        Handler handlerB = new HandleB();
        Handler handlerC = new HandleC();

        handlerA.setSucessor(handlerB);
        handlerB.setSucessor(handlerC);

        handlerA.execute();
    }
}

执行结果

handle by A
handle by B
handle by C

代码优化

由于在client类中调用时,都需要设置从属关系。现在就把链式关系的代码进行封装

Chain类 (封装调用关系)

package com.zhb.proxy_demo.chain;

import java.util.List;

/**
 * @author: curry
 * @Date: 2018/7/30
 */
public class Chain {
    private List<ChainHandler> handlers;

    private int index = 0;
    public Chain(List<ChainHandler> handlers) {
        this.handlers = handlers;
    }

    public void proceed(){
        if(index >= handlers.size()){
            return;
        }
        handlers.get(index++).execute(this);
    }
}

ChainHandler类

package com.zhb.proxy_demo.chain;

/**
 * @author: curry
 * @Date: 2018/7/30
 */
public abstract class ChainHandler {

    public void  execute(Chain chain){
        handleProcess();
        chain.proceed();
    }

    /**
     * 交给子类实现
     */
    protected abstract void handleProcess();
}

ChainClient类

package com.zhb.proxy_demo.chain;

import java.util.Arrays;
import java.util.List;

/**
 * @author: curry
 * @Date: 2018/7/30
 */
public class ChainClient {
    static class ChainHandlerA extends ChainHandler{
        @Override
        protected void handleProcess() {
            System.out.println("handler by A");
        }
    }
    static class ChainHandlerB extends ChainHandler{
        @Override
        protected void handleProcess() {
            System.out.println("handler by B");
        }
    }
    static class ChainHandlerC extends ChainHandler{
        @Override
        protected void handleProcess() {
            System.out.println("handler by C");
        }
    }

    public static void main(String[] args) {
        List<ChainHandler> handlers = Arrays.asList(
                new ChainHandlerA(),
                new ChainHandlerB(),
                new ChainHandlerC()
        );

        Chain chain = new Chain(handlers);
        chain.proceed();
    }
}

测试结果

handler by A
handler by B
handler by C

总结

其实多个aop作用于同一个对象的时候,就是利用了责任链模式。如同优化后的代码

ReflectiveMethodInvocation 类的代码

@Nullable
    public Object proceed() throws Throwable {
        if (this.currentInterceptorIndex == this.interceptorsAndDynamicMethodMatchers.size() - 1) {
            return this.invokeJoinpoint();
        } else {
            Object interceptorOrInterceptionAdvice = this.interceptorsAndDynamicMethodMatchers.get(++this.currentInterceptorIndex);
            if (interceptorOrInterceptionAdvice instanceof InterceptorAndDynamicMethodMatcher) {
                InterceptorAndDynamicMethodMatcher dm = (InterceptorAndDynamicMethodMatcher)interceptorOrInterceptionAdvice;
                return dm.methodMatcher.matches(this.method, this.targetClass, this.arguments) ? dm.interceptor.invoke(this) : this.proceed();
            } else {
                return ((MethodInterceptor)interceptorOrInterceptionAdvice).invoke(this);
            }
        }
    }
    

责任链模式将常用于过滤器,拦截器,事件(鼠标键盘事件,冒泡事件等)等场景

优点

  • 请求者和接收者解耦
  • 可以动态的增加或减少责任链上的对象,或者修改顺序

缺点

  • 调用者不知道请求可能被哪些责任链对象处理,不利于排错
  • 用户请求可能被责任链中途拦截,最终未必被真正执行,这点既是优点也是缺点,我们可以利用它做权限控制拦截器
学习不是要么0分,要么100分的。80分是收获;60分是收获;20分也是收获。有收获最重要。但是因为着眼于自己的不完美,最终放弃了,那就是彻底的0分了。
相关文章
|
9月前
|
设计模式 Java
【设计模式系列笔记】责任链模式
责任链模式是一种行为设计模式,它允许你将请求沿着处理者链进行传递,直到有一个处理者能够处理它。每个处理者都有一个对下一个处理者的引用。责任链模式常用于处理请求的场景,例如在一个请求需要经过多个步骤或者多个对象来处理的情况下。
107 0
|
9月前
|
设计模式 Java
【设计模式】责任链模式
【设计模式】责任链模式
|
9月前
|
设计模式
【设计模式】责任链模式
【1月更文挑战第27天】【设计模式】责任链模式
|
21天前
|
设计模式 存储 Java
「全网最细 + 实战源码案例」设计模式——责任链模式
责任链模式(Chain of Responsibility Pattern)是一种行为型设计模式,允许将请求沿着处理者链进行发送。每个处理者可以处理请求或将其传递给下一个处理者,从而实现解耦和灵活性。其结构包括抽象处理者(Handler)、具体处理者(ConcreteHandler)和客户端(Client)。适用于不同方式处理不同种类请求、按顺序执行多个处理者、以及运行时改变处理者及其顺序的场景。典型应用包括日志处理、Java Web过滤器、权限认证等。
56 13
「全网最细 + 实战源码案例」设计模式——责任链模式
|
3月前
|
设计模式 JavaScript Scala
Kotlin - 改良设计模式 - 责任链模式
Kotlin - 改良设计模式 - 责任链模式
54 3
|
4月前
|
设计模式 JavaScript Scala
Kotlin - 改良设计模式 - 责任链模式
Kotlin - 改良设计模式 - 责任链模式
68 9
|
3月前
|
设计模式 JavaScript Scala
Kotlin教程笔记(55) - 改良设计模式 - 责任链模式
Kotlin教程笔记(55) - 改良设计模式 - 责任链模式
41 0
|
3月前
|
设计模式 JavaScript Scala
Kotlin教程笔记(55) - 改良设计模式 - 责任链模式
Kotlin教程笔记(55) - 改良设计模式 - 责任链模式
51 0
|
4月前
|
设计模式 JavaScript Scala
Kotlin - 改良设计模式 - 责任链模式
本教程详细讲解了Kotlin语法,适合需要深入了解Kotlin的开发者。对于希望快速上手Kotlin的读者,推荐查阅“简洁”系列教程。本文通过学生会经费申请的例子,介绍了责任链模式及其在Kotlin中的实现,并使用偏函数进行了改进,使代码更加简洁和灵活。
29 0
|
4月前
|
设计模式 JavaScript Scala
Kotlin - 改良设计模式 - 责任链模式
Kotlin - 改良设计模式 - 责任链模式
50 0