SpringAOP(1)-spring源码详解(六)

本文深入探讨了Spring框架中的AOP(面向切面编程)机制与事件监听器的功能。详细介绍了AOP如何利用动态代理实现代码增强,并解析了事件监听器的工作原理及其在解耦和异步操作中的应用。

上篇文章说了spring监听器,监听event,先把事件全部存储在多播器,通过publicEvent来触发多播器发送事件,他可以通过代码注解,或者实现接口的方式来实现事件监听,达到解耦和异步的效果。

Spring监听器-spring源码详解(五)icon-default.png?t=M85Bhttps://blog.csdn.net/ke1ying/article/details/127780075

Aop要实现的是在我们原来的代码基础上进行一些包装,比如在方法执行前,方法抛出异常之后进行拦截处理,又叫增强处理。与前面ioc的一些后置处理器构造方法不同,aop主要是动态代理来实现的。

SpringAop是基于动态代理,当使用接口的时候是jdk动态代理实现,不是则是用cglib来实现。(cglb是通过asm开源框架动态修改底层字节码,修改需要被增强的.class)

Spring主要用到aspect切点解析,注解。

除了上面的@aspct来增强外,还可以通过实现interceptor的方式来做一些增强。

@Aspect,@Before,@after

拿到所有bean定义,是不是标记了@aspect,每个通知都会生成一个advisor。里面有advise

和pointcut。

那倒是所有advisors之后,pointcut然后matches创建动态proxy。

 

通过@EnableAspectJAutoProxy可以注册一个bean定义。

解析切面的第一步就是在postProcessorBeforeInstiation里。

 

 

 

 

创建动态代理AbstractAutoProxyCreator里的后置处理器。

判断是否直接跳过,跳过的规则是,判断是不是切面类,通知类,切点类,advice,pointcut,advisor等,如果是,则返回true。

当findCandidateAdvisors找不到的时候,会调用buildAspectJAdvisors方法解析所有的切面。

在这里会循环Object的bean定义,也就是拿到所有beanName,判断是不是aspect切面。

主要通过判断findAnnotation 是否标记aspect注解。

这里有个回调钩子方法,会把pointCut注解的忽略掉,没有则加到methods里面去。

这里会有一个sort排序,为什么排序呢,因为后面会根据责任链调用。

Around,before,after,afterReturning,afterTrowing。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

后端从入门到精通

你的鼓励是我最大的动力~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值