学习spring aop的过程中遇到了关于执行顺序的先后问题
定义了两个类,分别是log类和exception类
logAop类用来实现Before advice和After advice,exceptionAop用来实现After throwing advice
用order来定义优先级
Before advice优先级越高就在越前面执行
After advice优先级越高就越靠后执行
当Before advice的优先级比After throwing advice优先级高的时候(即logAop类的advice方法在exceptionAop类的advice方法之前执行)
logAop.advice();//Before advice
try{
add();//被增强的原方法
}catch(Exception e){
exceptionAop.advice();//After throwing advice
}
logAop的advice方法在exceptionAop的try块之前执行
当Before advice的优先级比After throwing advice优先级低的时候(即logAop类的advice方法在exceptionAop类的advice方法之后执行)
try{
logAop.advice();//Before advice
add();//被增强的原方法
}catch(Exception e){
exceptionAop.advice();//After throwing advice
}
logAop的advice方法在exceptionAop的try块内执行
Before advice的执行是在被切面增强的原方法(即add())之前执行,虽然优先级比After throwing advice低,但是最终执行顺序却是logAop.advice()在exceptionAop.advice之前执行
After throwing advice的执行是在被切面增强的原方法(即add())出现异常的时候执行
当After advice的优先级比After throwing advice优先级高的时候(即logAop类的advice方法在exceptionAop类的advice方法之后执行)
try{
add();//被增强的原方法
}catch(Exception e){
exceptionAop.advice();//After throwing advice
}
logAop.advice();//After advice
logAop的advice方法在exceptionAop的catch块之后执行
当After advice的优先级比After throwing advice优先级低的时候(即logAop类的advice方法在exceptionAop类的advice方法之前执行)
try{
add();//被增强的原方法
logAop.advice();//After advice
}catch(Exception e){
exceptionAop.advice();//After throwing advice
}
logAop的advice方法在exceptionAop的try块内执行
无论Before advice还是After advice以及After throwing advice或者本文没有提及的After return advice和Around advice,都是围绕着JoinPoint(即本文中的add方法)展开的
调用的顺序也是和JoinPoint密切相关