AOP原理-创建AOP代理--AnnotationAwareAspectJAutoProxyCreator【InstantiationAwareBeanPostProcessor】的作用

AnnotationAwareAspectJAutoProxyCreator 

InstantiationAwareBeanPostProcessor

* AnnotationAwareAspectJAutoProxyCreator【InstantiationAwareBeanPostProcessor】的作用:
* 1)、每一个bean创建之前,调用postProcessBeforeInstantiation();
*     关心MathCalculator和LogAspect的创建
*     1)、判断当前bean是否在advisedBeans中(保存了所有需要增强bean)
*     2)、判断当前bean是否是基础类型的Advice、Pointcut、Advisor、AopInfrastructureBean,或者是否是切面(@Aspect)
*     
*     3)、是否需要跳过
*        1)、获取候选的增强器(切面里面的通知方法)【List<Advisor> candidateAdvisors】
*           每一个封装的通知方法的增强器是 InstantiationModelAwarePointcutAdvisor;
*           判断每一个增强器是否是 AspectJPointcutAdvisor 类型的;返回true
*        2)、永远返回false
*
* 2)、创建对象
* postProcessAfterInitialization;
*     return wrapIfNecessary(bean, beanName, cacheKey);//包装如果需要的情况下
*     1)、获取当前bean的所有增强器(通知方法)  Object[]  specificInterceptors
*        1、找到候选的所有的增强器(找哪些通知方法是需要切入当前bean方法的)
*        2、获取到能在bean使用的增强器。
*        3、给增强器排序
*     2)、保存当前bean在advisedBeans中;
*     3)、如果当前bean需要增强,创建当前bean的代理对象;
*        1)、获取所有增强器(通知方法)
*        2)、保存到proxyFactory
*        3)、创建代理对象:Spring自动决定
*           JdkDynamicAopProxy(config);jdk动态代理;
*           ObjenesisCglibAopProxy(config);cglib的动态代理;
*     4)、给容器中返回当前组件使用cglib增强了的代理对象;
*     5)、以后容器中获取到的就是这个组件的代理对象,执行目标方法的时候,代理对象就会执行通知方法的流程;
*
*
*  3)、目标方法执行  ;
*     容器中保存了组件的代理对象(cglib增强后的对象),这个对象里面保存了详细信息(比如增强器,目标对象,xxx);
*     1)、CglibAopProxy.intercept();拦截目标方法的执行
*     2)、根据ProxyFactory对象获取将要执行的目标方法拦截器链;
*        List<Object> chain = this.advised.getInterceptorsAndDynamicInterceptionAdvice(method, targetClass);
*        1)、List<Object> interceptorList保存所有拦截器 5
*           一个默认的ExposeInvocationInterceptor 和 4个增强器;
*        2)、遍历所有的增强器,将其转为Interceptor;
*           registry.getInterceptors(advisor);
*        3)、将增强器转为List<MethodInterceptor>;
*           如果是MethodInterceptor,直接加入到集合中
*           如果不是,使用AdvisorAdapter将增强器转为MethodInterceptor;
*           转换完成返回MethodInterceptor数组;
*
*     3)、如果没有拦截器链,直接执行目标方法;
*        拦截器链(每一个通知方法又被包装为方法拦截器,利用MethodInterceptor机制)
*     4)、如果有拦截器链,把需要执行的目标对象,目标方法,
*        拦截器链等信息传入创建一个 CglibMethodInvocation 对象,
*        并调用 Object retVal =  mi.proceed();
*     5)、拦截器链的触发过程;
*        1)、如果没有拦截器执行执行目标方法,或者拦截器的索引和拦截器数组-1大小一样(指定到了最后一个拦截器)执行目标方法;
*        2)、链式获取每一个拦截器,拦截器执行invoke方法,每一个拦截器等待下一个拦截器执行完成返回以后再来执行;
*           拦截器链的机制,保证通知方法与目标方法的执行顺序;


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值