关于@Around、@Before、@After、@AfterReturning、@AfterThrowing执行顺序以及执行结果总结

2年前 (2022) 程序员胖胖胖虎阿
312 0 0

spring4.x版本的执行结果顺序是:

@Around注解方法的前半部分业务逻辑
->@Before注解方法的业务逻辑
->目标方法的业务逻辑
->@Around注解方法的后半部分业务逻辑(@Around注解方法内的业务逻辑若对ProceedingJoinPoint.proceed()方法没做捕获异常处理,直接向上抛出异常,则不会执行Around注解方法的后半部分业务逻辑;若做了异常捕获处理,则会执行)。
->@After(不管目标方法有无异常,都会执行@After注解方法的业务逻辑)
->@AfterReturning(若目标方法无异常,执行@AfterReturning注解方法的业务逻辑)
->@AfterThrowing(若目标方法有异常,执行@AfterThrowing注解方法的业务逻辑)

我的spring源码版本是5.2.14,之前一直没搞明白五大通知的执行结果,特此记录。

前菜:切面类业务代码

关于@Around、@Before、@After、@AfterReturning、@AfterThrowing执行顺序以及执行结果总结

关于@Around、@Before、@After、@AfterReturning、@AfterThrowing执行顺序以及执行结果总结

要被增强的类及方法:

关于@Around、@Before、@After、@AfterReturning、@AfterThrowing执行顺序以及执行结果总结
当执行MathCalculator.div方法时,会触发aop进而执行增强的业务,它的拦截器链数组如下,
[
  ExposeInvocationInterceptor,
  AspectJAroundAdvice,
  MethodBeforeAdviceInterceptor,
  AspectJAfterAdvice,
  AfterReturningAdviceInterceptor,
  AspectJAfterThrowingAdvice
]

关于@Around、@Before、@After、@AfterReturning、@AfterThrowing执行顺序以及执行结果总结
按照这个链数组从角标0开始顺序执行invoke方法,invoke方法中递归执行ReflectiveMethodInvocation的proceed方法。
执行流程大致如下:
@Around前半部分(执行Around注解的方法内ProceedingJoinPoint.proceed()之前的代码逻辑并通过ProceedingJoinPoint.proceed()方法递归调用到Before拦截器)
->@Before
->@After(使用了try...finally结构,try代码块中继续递归调用AfterReturning,finally代码块中是执行after注解的方法逻辑)
->@AfterReturning
->@AfterThrowing
->目标方法执行(开始往回返数据,即return)
->@AfterThrowing(无异常return数据,有异常捕获异常执行AfterThrowing注解的方法逻辑并再次抛出异常)
->@AfterReturning(执行AfterReturning注解的方法逻辑并return目标方法执行结果)
->@After(执行After注解的方法逻辑并return目标方法执行结果)
->@Before(return目标方法执行结果)
->@Around后半部分(执行Around注解的方法内ProceedingJoinPoint.proceed()之后的代码逻辑并return目标方法执行结果)。

以上就是大致的执行流程。
总结:所以包含通知注解的执行结果如下,
@Around注解方法的前半部分业务逻辑
->@Before注解方法的业务逻辑
->目标方法的业务逻辑
->@AfterThrowing(若目标方法有异常,执行@AfterThrowing注解方法的业务逻辑)
->@AfterReturning(若目标方法无异常,执行@AfterReturning注解方法的业务逻辑)
->@After(不管目标方法有无异常,都会执行@After注解方法的业务逻辑)
->@Around注解方法的后半部分业务逻辑(@Around注解方法内的业务逻辑若对ProceedingJoinPoint.proceed()方法没做捕获异常处理,直接向上抛出异常,则不会执行Around注解方法的后半部分业务逻辑;若做了异常捕获处理,则会执行)。

正常执行结果如下:

关于@Around、@Before、@After、@AfterReturning、@AfterThrowing执行顺序以及执行结果总结

 抛异常结果如下:

关于@Around、@Before、@After、@AfterReturning、@AfterThrowing执行顺序以及执行结果总结

 如果我理解的内容有误,烦请评论区留言或者私聊,我好及时纠正,谢谢!

相关文章

暂无评论

暂无评论...