责任链模式

定义:

将处理请求的多个对象连成一条链,链上的每个对象都有机会处理该请求,请求会沿着这条链进行传递,直到它被某个对象处理为止。

设计类图:

责任链模式的主要角色就是Handler处理者对象,通过类图可以发现它主要有两个特点,一个是可以处理请求的方法,还有就是可以设置下一个处理者对象。其中ConcreteHandler是具体的处理者,可以有多个。

示例代码:

public abstract class Handler {
    private Handler successor;
    private int handleLevel;

    public Handler(int handleLevel) {
        //每个处理者必须要知道自己能够处理的级别或者范围
        this.handleLevel = handleLevel;
    }

    /**
     * 处理请求对象
     */
    public Response handleRequest(Request request) {
        //如果请求是当前处理者能够处理的,就由当前处理者处理
        if (request.getLevel() == this.handleLevel) {
            return handleBusiness();
        } else {
            //否则,交由下一个处理者处理(如果有)
            if (successor != null) {
                return successor.handleRequest(request);
            }
        }
        return new Response("No Handler Found!");
    }

    /**
     * 设置下一个处理者对象
     */
    public  void setNextHandler(Handler handler) {
        successor = handler;
    }

    /**
     * 当前处理者真正处理业务逻辑的方法
     */
    public abstract Response handleBusiness();

}
public class ConcreteHandler1 extends Handler {

    public ConcreteHandler1(int handleLevel) {
        super(handleLevel);
    }

    @Override
    public Response handleBusiness() {
        System.out.println("ConcreteHandler1进行处理");
        return new Response("来自ConcreteHandler1的处理结果");
    }
}
public class ConcreteHandler2 extends Handler {

    public ConcreteHandler2(int handleLevel) {
        super(handleLevel);
    }

    @Override
    public Response handleBusiness() {
        System.out.println("ConcreteHandler2进行处理");
        return new Response("来自ConcreteHandler2的处理结果");
    }
}
public class ConcreteHandler3 extends Handler {

    public ConcreteHandler3(int handleLevel) {
        super(handleLevel);
    }

    @Override
    public Response handleBusiness() {
        System.out.println("ConcreteHandler3进行处理");
        return new Response("来自ConcreteHandler3的处理结果");
    }
}
public class Request {
    private int level;

    public Request(int level) {
        this.level = level;
    }

    public int getLevel() {
        return level;
    }
}
public class Response {
    String result;

    public Response(String result) {
        this.result = result;
    }

    public String getResult() {
        return result;
    }
}
public class Client {

    public static void main(String[] args) {

        Handler handler1 = new ConcreteHandler1(1);
        Handler handler2 = new ConcreteHandler2(2);
        Handler handler3 = new ConcreteHandler3(3);

        handler1.setNextHandler(handler2);
        handler2.setNextHandler(handler3);

        System.out.println("处理第一个请求 级别为1:");
        Request request = new Request(1);
        Response response = handler1.handleRequest(request);
        System.out.println("处理结果:");
        System.out.println(response.getResult());

        System.out.println("-------------------------------");

        System.out.println("处理第二个请求 级别为2:");
        request = new Request(2);
        response = handler1.handleRequest(request);
        System.out.println("处理结果:");
        System.out.println(response.getResult());

        System.out.println("-------------------------------");

        System.out.println("处理第三个请求 级别为3:");
        request = new Request(3);
        response = handler1.handleRequest(request);
        System.out.println("处理结果:");
        System.out.println(response.getResult());

    }
}

输出结果:
这里写图片描述

  通过输出结果可以看到。每一个级别的请求都得到了对应级别的处理者的正确的处理。在上面代码中设置了每个处理者当前能够处理的级别,当然这里只是示例,这里的级别可以是你的其它的约束判断条件。当请求被发出后,就不需要关心后面的事情,完全由Handler内部来判断该请求是否是由当前的Handler来处理还是交由下一个来处理。不同级别的请求在责任链中传递时满足条件的处理者自然会处理它。
在这里插入图片描述
  如图,责任链模式使得链条上面的每一个处理者都有机会对请求进行处理或者传递给下家,当某一个处理者处理了该请求并返回后,请求过程就结束了。责任链上的每一个处理者内部的逻辑是相互独立的,这样每个处理者能够专注于自己要干的事,职责上更加清晰明确。

责任链模式的优缺点

  优点就是将请求和处理过程进行了解耦,请求不需要知道处理的全过程,处理者也不用关心整个过程,只需要关心自己需要处理的部分。还有一个优点就是,你可以动态的改变责任链上处理者的次序或者是动态的新增删除一个处理者。缺点是链条比较长的时候,会产生性能问题,因为必须沿着链条一个一个的过才能知道最终被哪个处理,假如处理者正好处于链尾,就会耗时比较长。另外链条比较长的话,可能调试排错也会比较麻烦些。

  当然实际当中优点带来的影响能够盖过缺点带来的影响的话,还是可以尝试使用的,比如我有不同类型的注册用户,针对不同的请求不同类型的注册用户需要做出不同的响应,这时就很适合责任链模式来处理,它可以代替你的一大堆的if-else条件判断了。


参考:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

川峰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值