spring aop学习9:Aop的链式调用(责任链模式)

一.责任链模式
1.基本的责任链模式
◆主体父类:abstract class Subject.java

package com.tiglle.responsibility.chain.model;
//主体
public abstract class Subject {

    private Subject successor;

    protected abstract void handle();

    public void execute(){
        handle();
        if(successor!=null){
            successor.execute();
        }
    }

    public Subject getSuccessor() {
        return successor;
    }

    public void setSuccessor(Subject successor) {
        this.successor = successor;
    }

}

◆子类和测试main方法:MainExec.java

package com.tiglle.responsibility.chain.model;

public class MainExec {

    private static class Part1 extends Subject{
        @Override
        protected void handle() {
            System.out.println("Part1的handle");
        }
    }
    private static class Part2 extends Subject{
        @Override
        protected void handle() {
            System.out.println("Part2的handle");
        }
    }
    private static class Part3 extends Subject{
        @Override
        protected void handle() {
            System.out.println("Part3的handle");
        }
    }


    public static void main(String[] args) {
        Part1 part1 = new Part1();
        Part2 part2 = new Part2();
        Part3 part3 = new Part3();

        part1.setSuccessor(part2);
        part2.setSuccessor(part3);

        part1.execute();
    }

}

执行结果:
Part1的handle
Part2的handle
Part3的handle

原理:
执行Part1继承自父类的execute()方法,首先执行Part1重写了父类抽象方法handle(),然后判断successor(此时successor为Part2)是否为null

此时successor(Part2)不为null,执行Part2的execute,首先执行Part2重写了父类抽象方法handle(),然后判断successor(此时successor为Part3)是否为null

此时successor(Part3)不为null,执行Part3的execute,首先执行Part3重写了父类抽象方法handle(),然后判断successor(Part3的successor为null)是否为null,为null,停止执行

2.优化的责任链模式
◆主体父类:abstract class Subject.java

package com.tiglle.responsibility.chain.model.optimization;

public abstract class Subject {

    protected abstract void handle();

    public void execute(SubjectChain successor){
        handle();
        successor.process();
    }
}

◆中间类:class SubjectChain.java

package com.tiglle.responsibility.chain.model.optimization;

import java.util.List;

public class SubjectChain {

    private List<Subject> successors;

    public SubjectChain(List<Subject> successors){
        this.successors = successors;
    }

    private int index = 0;

    public void process(){
        if(index < successors.size()){
            successors.get(index++).execute(this);
        }
    }
}

◆测试main方法:MainExec.java

package com.tiglle.responsibility.chain.model.optimization;

import java.util.ArrayList;
import java.util.List;

public class MainExec {

    private static class Part1 extends Subject{
        @Override
        protected void handle() {
            System.out.println("Part1的handle");
        }
    }

    private static class Part2 extends Subject{
        @Override
        protected void handle() {
            System.out.println("Part2的handle");
        }
    }

    private static class Part3 extends Subject{
        @Override
        protected void handle() {
            System.out.println("Part3的handle");
        }
    }

    public static void main(String[] args) {
        Part1 part1 = new Part1();
        Part2 part2 = new Part2();
        Part3 part3 = new Part3();
        List<Subject> successors = new ArrayList<>();
        successors.add(part1);
        successors.add(part2);
        successors.add(part3);

        SubjectChain subjectChain = new SubjectChain(successors);
        subjectChain.process();
    }
}


执行结果:
Part1的handle
Part2的handle
Part3的handle

原理:两个方法的互相调用,并设置中断条件

二.spring aop的链式调用使用的第二种方法:
源码:

@Override
    public Object proceed() throws Throwable {
        //  We start with an index of -1 and increment early.
        //从-1开始每次加1
        if (this.currentInterceptorIndex == this.interceptorsAndDynamicMethodMatchers.size() - 1) {
            return invokeJoinpoint();
        }

        Object interceptorOrInterceptionAdvice =
                this.interceptorsAndDynamicMethodMatchers.get(++this.currentInterceptorIndex);
        if (interceptorOrInterceptionAdvice instanceof InterceptorAndDynamicMethodMatcher) {
            // Evaluate dynamic method matcher here: static part will already have
            // been evaluated and found to match.
            InterceptorAndDynamicMethodMatcher dm =
                    (InterceptorAndDynamicMethodMatcher) interceptorOrInterceptionAdvice;
            //
            if (dm.methodMatcher.matches(this.method, this.targetClass, this.arguments)) {
                return dm.interceptor.invoke(this);
            }else {
                // Dynamic matching failed.
                // Skip this interceptor and invoke the next in the chain.
                return proceed();
            }
        }else {
            // It's an interceptor, so we just invoke it: The pointcut will have
            // been evaluated statically before this object was constructed.
            return ((MethodInterceptor) interceptorOrInterceptionAdvice).invoke(this);
        }
    }
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring AOP中,拦截器责任处理过程是指当目标方法被多个通知匹配到时,Spring通过引入拦截器来保证每个通知的正常执行。拦截器是由一系列的拦截器组成的,每个拦截器都负责在目标方法的前后执行特定的逻辑。 在源码中,拦截器责任的处理过程主要通过MethodInvocation接口来实现。MethodInvocation接口提供了proceed()方法,用于执行拦截器中下一个拦截器的逻辑。当调用proceed()方法时,会按照拦截器的顺序依次执行每个拦截器的逻辑,直到达到的末尾或者某个拦截器决定终止的执行。 在拦截器责任处理过程中,每个拦截器可以在目标方法的调用前后执行自定义的逻辑。拦截器可以对方法的参数进行检查、修改方法的返回值,或者在方法执行前后记录日志等操作。通过拦截器责任的处理,Spring AOP能够实现面向切面编程的功能。 需要注意的是,拦截器的执行顺序是根据拦截器的配置顺序确定的。在Spring的配置文件中,可以通过配置拦截器的顺序来控制拦截器的执行顺序。这样可以确保每个拦截器按照预期的顺序执行,从而达到期望的功能效果。 总结起来,Spring AOP源码的拦截器责任处理过程主要通过MethodInvocation接口实现,它通过调用proceed()方法来依次执行拦截器中每个拦截器的逻辑。拦截器的执行顺序可以通过配置文件来控制,从而实现面向切面编程的功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Spring AOP源码:拦截器责任处理过程](https://blog.csdn.net/weixin_45031612/article/details/128806966)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Spring AOP 自动代理源码 DefaultAdvisorAutoProxyCreator](https://download.csdn.net/download/weixin_38530536/14854229)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [【SpringSpring AOP 源码分析-拦截器的执行过程(四)](https://blog.csdn.net/qq_46514118/article/details/121912507)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值