责任链模式详解+代码案例

责任链设计模式

定义:

又名职责链模式,为了避免请求发送者与多个请求处理者耦合在一起,将所有请求的处理者通过前一对象记住其下一个对象的引用而连成一条链;当有请求发生时,可将请求沿着这条链传递,直到有对象处理它为止。

比较常见的springmvc中的拦截器,web开发中的filter过滤器

结构

职责链模式主要包含以下角色:

  • 抽象处理者(Handler)角色:定义一个处理请求的接口,包含抽象处理方法和一个后继连接。
  • 具体处理者(Concrete Handler)角色:实现抽象处理者的处理方法,判断能否处理本次请求,如果可以处理请求则处理,否则将该请求转给它的后继者。
  • 客户类(Client)角色:创建处理链,并向链头的具体处理者对象提交请求,它不关心处理细节和请求的传递过程。

下面代码以订单入库验证流程演示责任链模式在开发当中的实际应用

抽象处理者

/**
 * 抽象处理者
 */
public abstract class Handler {
    protected Handler handler;
    public void setNext(Handler handler) {
        this.handler = handler;
    }
    /**
     * 处理过程
     * 需要子类进行实现
     */
    public abstract void process(OrderInfo order);
}

订单信息类:

public class OrderInfo {
    private String productId;
    private String userId;
    private BigDecimal amount;
}

具体处理者:

/**
 * 订单校验
 */
public class OrderValidition extends Handler {

    @Override
    public void process(OrderInfo order) {
        System.out.println("校验订单基本信息");
        //校验
        this.handler.process(order);
    }
}


/**
 * 补充订单信息
 */
public class OrderFill extends Handler {
    @Override
    public void process(OrderInfo order) {
        System.out.println("补充订单信息");
        this.handler.process(order);
    }
}


/**
 * 计算金额
 */
public class OrderAmountCalcuate extends Handler {
    @Override
    public void process(OrderInfo order) {
        System.out.println("计算金额-优惠券、VIP、活动打折");
        this.handler.process(order);
    }
}


/**
 * 订单入库
 */
public class OrderCreate extends Handler {
    @Override
    public void process(OrderInfo order) {
        System.out.println("订单入库");
    }
}

客户类:

public class Application {

    public static void main(String[] args) {
        //检验订单
        Handler orderValidition = new OrderValidition();
        //补充订单信息
        Handler orderFill = new OrderFill();
        //订单算价
        Handler orderAmountCalcuate = new OrderAmountCalcuate();
        //订单落库
        Handler orderCreate = new OrderCreate();
        //设置责任链路
        orderValidition.setNext(orderFill);
        orderFill.setNext(orderAmountCalcuate);
        orderAmountCalcuate.setNext(orderCreate);
        //开始执行
        orderValidition.process(new OrderInfo());
    }
}

总结

其实这段代码完全可以写成一段代码的形式,我们这里使用责任链模式做拆饭是为了遵循软件设计中的开闭原则,否则完全不需要这样从子类一路层层调用

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
AutowireCandidateResolver是Spring框架中用于解决自动装配时的依赖冲突问题的一个接口。在进行自动装配时,如果有多个bean都能够满足注入的需求,就会出现依赖冲突问题。而AutowireCandidateResolver就是用来解决这种冲突的。 AutowireCandidateResolver接口中定义了两个方法: 1. boolean isAutowireCandidate(BeanDefinitionHolder bdHolder, DependencyDescriptor descriptor) 该方法用于判断一个bean是否是自动装配的候选者。其中bdHolder表示bean的定义信息,descriptor表示注入点的描述信息。返回值为true表示该bean是自动装配的候选者。 2. Object getSuggestedValue(DependencyDescriptor descriptor) 该方法用于获取某个注入点的建议值。其中descriptor表示注入点的描述信息。返回值为建议的值。 以下是一个AutowireCandidateResolver的代码案例: ``` public class MyAutowireCandidateResolver implements AutowireCandidateResolver { @Override public boolean isAutowireCandidate(BeanDefinitionHolder bdHolder, DependencyDescriptor descriptor) { // 判断是否是特定类型的bean if (descriptor.getDependencyType().equals(MyClass.class)) { // 判断bean的名称是否以"my"开头 return bdHolder.getBeanName().startsWith("my"); } return true; } @Override public Object getSuggestedValue(DependencyDescriptor descriptor) { // 返回一个MyClass类型的建议值 return new MyClass(); } } ``` 在这个案例中,我们重写了AutowireCandidateResolver的isAutowireCandidate和getSuggestedValue方法。isAutowireCandidate方法用于判断是否是特定类型的bean,并且bean的名称是否以"my"开头。getSuggestedValue方法则返回一个MyClass类型的建议值。 然后,我们可以将自定义的AutowireCandidateResolver实例设置到BeanFactory中,来解决自动装配时的依赖冲突问题: ``` DefaultListableBeanFactory beanFactory = new DefaultListableBeanFactory(); beanFactory.setAutowireCandidateResolver(new MyAutowireCandidateResolver()); ``` 这样,在进行自动装配时,就会使用我们自定义的AutowireCandidateResolver来解决依赖冲突问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值