职责链模式

职责链模式
也叫责任链模式(Chain of Responsibility Pattern)为请求创建了一个接收者对象的链。这种模式给予请求的类型,对请求的发送者和接收者进行解耦。这种类型的设计模式属于行为型模式。
在这种模式中,通常每个接收者都包含对另一个接收者的引用。如果一个对象不能处理该请求,那么它会把相同的请求传给下一个接收者,依此类推。

意图:避免请求发送者与接收者耦合在一起,让多个对象都有可能接收请求,将这些对象连接成一条链,并且沿着这条链传递请求,直到有对象处理它为止。
主要解决:职责链上的处理者负责处理请求,客户只需要将请求发送到职责链上即可,无须关心请求的处理细节和请求的传递,所以职责链将请求的发送者和请求的处理者解耦了。
何时使用:在处理消息的时候以过滤很多道。
如何解决:拦截的类都实现统一接口。
应用:拦截器、过滤器


/**
 * 描述:职责链模式的应用 - 过滤器的实现
 *
 * 我是LoginFilter,我在你之前处理了消息:http://www.baidu.com
 * "我是EncodeFilter,我在你之前处理了消息:http://www.baidu.com"
 * 所有filter处理完成(url交给servlet)
 * System.out.println("我是EncodeFilter,我在你之后处理了消息:http://www.baidu.com"
 * "我是LoginFilter,我在你之后处理了消息:" + msg);
 *
 */
interface Filter{
    void doFilter(String msg, FilterChain chain);
}


interface FilterChain{
    void add(Filter filter);
    void doFilter(String msg);
}

class ConcreteFilterChain implements FilterChain{
    ArrayList<Filter> list = new ArrayList<Filter>();
    private int index = 0;
    @Override
    public void add(Filter filter) {
        list.add(filter);
    }
    @Override
    public void doFilter(String msg) {

        if(index<list.size()){
            list.get(index++).doFilter(msg,this);
        }
    }
    public void submit(String msg){
       doFilter(msg);
    }
}



class LoginFilter implements Filter{

    @Override
    public void doFilter(String msg, FilterChain chain) {
        System.out.println("我是LoginFilter,我在你之前处理了消息:" + msg);
        chain.doFilter(msg);
        System.out.println("我是LoginFilter,我在你之后处理了消息:" + msg);
    }
}

class EncodeFilter implements Filter{

    @Override
    public void doFilter(String msg, FilterChain chain) {
        System.out.println("我是EncodeFilter,我在你之前处理了消息:" + msg);
        chain.doFilter(msg);
        System.out.println("我是EncodeFilter,我在你之后处理了消息:" + msg);

    }
}
public class FilterChainTest {
    public static void main(String[] args) {
        ConcreteFilterChain cfc = new ConcreteFilterChain();
        cfc.add(new LoginFilter());
        cfc.add(new EncodeFilter());
        cfc.submit("http://www.baidu.com");
    }
}

这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值