AOP实现原理 以@EnableAspectJAutoProxy+@Aspect举例说明

以@EnableAspectJAutoProxy+@Aspect实现方式为例(这种目前用的做多,且最方便使用,其他的实现方式大同小异)

@EnableAspectJAutoProxy注解都干了什么:

一层一层点进去会发现他是通过@Import(AspectJAutoProxyRegistrar.class):给容器中导入AspectJAutoProxyRegistrar注册器,注册器中的registerBeanDefinitions接口方法中实现的是向容器中注册一个AnnotationAwareAspectJAutoProxyCreator,他继承了关键接口:InstantiationAwareBeanPostProcessor (InstantiationAwareBeanPostProcessor 继承自BeanPostProcessor)所以他归根结底就是个后置处理器

AnnotationAwareAspectJAutoProxyCreator后置处理器主要作用:

主要就是用于在bean实例化之前调用的是postProcessBeforeInstantiation方法,主要进行了一些必要判断,以及如果通知方法list集合为空,进行遍历所有@Aspect等先关声明切面注解的类,并解析该类中的各个切面和切面类型为一个个的通知方法保存到list中(这个list位于这个后置处理器的aspectJAdvisorsBuilder属性下的advisorsCache属性中),在bean实例化后调用后置处理器的postProcessAfterInitialization用于将对象生成动态代理对象返回放入容器中(跟该类被切方法相关的通知方法的集合会参与代理类的生成)。这里需要额外一提的是如果涉及到了循环引用,对象需要进行早期暴露,那么必须暴露出去的是代理对象,而不能是未代理的原始bean实例,所以如果对象参与进了循环引用那么他的代理对象的生成是在对外暴露早期引用时的方法getEarlyBeanReference中进行wrapIfNecessary的,提前暴露代理对象;

生成动态代理对象过程:

在执行后置处理器的postProcessAfterInitialization方法时,如果判断bean需要被代理,判断使用哪种方式代理,有实现接口的使用JDK动态代理,否则使用CGLIB(可以主动指定都用CGLIB),找到所有符合该bean的通知方法增强器,使用按一定规则排序后这些通知方法的增强器创建代理对象, 返回当前组件使用cglib增强了的代理对象给容器; 以后容器中获取到的就是这个组件的代理对象,执行目标方法的时候,代理对象就会执行通知方法的流程;

被切的方法执行:

凡是调用到被切片的方法,对应切片的通知方法会以拦截器链的方式进行迭代调用,(类似springmvc中的拦截器,在真正的逻辑方法前后执行);

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值