--------------------------爸爸级别的: AspectJAutoProxyRegistrar 通过ConfigurationClassBeanDefinitionReader的loadBeanDefinitionFromRegistrars方法加载bd
AnnotationAwareAspectJAutoProxyCreator
AspectJAwareAdvisorAutoProxyCreator
AbstractAdvisorAutoProxyCreator
AbstractAutoProxyCreator
SmartInstantiationAwareBeanPostProcessor
AnnotationAwareAspectJAutoProxyCreator :
1、 主要作用就是去查找ioc容器中所有符合条件的候选织入器(Advisor)列表
2、 判断一个beanClass是否是符合AOP基础建设的条件,首先当前容器中的切面织入器工厂不能为空,因为这个玩意就是获取advisors的,第二个硬性条件就是,必须是切面类
AspectJAwareAdvisorAutoProxyCreator
1、对传入的织入器列表进行排序
2、对传入的候选织入器列表进行扩展,在织入链的头部插入一ExposeInvocationInterceptor对象,这个对象持有1个DefaultPointcutAdvisor通知实例
3、基于当前beanClass和name来判断是否需要跳过处理,如果等于true,说明当前beanClass是切面类,如果是的话,就不会走包装过程了,也就是切面类无法wrap成代理对象
补充一个知识点:如何找到ioc容器中所有符合条件的advisors并缓存起来呢,通过什么类呢?直接给出答案,就是BeanFactoryAdvisorRetrievalHelper类的方法findAdvisorBeans()
AbstractAdvisorAutoProxyCreator
1、基于给定的beanClass和beanName,去找对应符合条件的织入器列表,findEligibleAdvisors,Advisor的类型最终是InstantiationModelAwarePointcutAdvisorImpl
2、查询所有符合条件的候选织入器列表,findCandidateAdvisors
3、从当前(所有)候选织入器列表中找到符合beanClass和beanName的织入器列表,findAdvisorsThatCanApply(这个功能很实用的)
4、对所有织入器列表进行排序
5、预留一个protected类型的extendAdvisors方法,让子类AspectJAwareAdvisorAutoProxyCreator实现扩展功能,其实就是在织入链的头部插入一个ExposeInvocationInteceptor对象,这个对象持有一个advisor 即 DefaultPointcutAdvisor
AbstractAutoProxyCreator
1、提供各种aop配置,比如是否设置冻结动态代理setFrozen方法,如果传入true,则当前切面类不能在添加额外的通知advice,提供设置beanFactory,设置织入适配器注册表(当然是有默认的)、设置拦截器名称数组等
2、预测bean的类型
3、一个非常重要的方法,getEarlyBeanReference(Object bean,String beanName),获取bean的早期引用对象,这个地方用在ioc实例化bean的时候,一旦涉及bean的三级缓存调用,且发生了aop。就会调用这个
因为AbstractAutoProxyCreator实现了SmartInstantiationAwareBeanPostProcessor
4、实现了postProcessBeforeInstantiation和postProcessAfterInstantiation、postProcessBeforInitialization、postProcessAfterInitialization等父接口的方法
5、判断当前的beanClass是否是属于AOP基础设施的对象,如果是返回true,这个方法的用图就是,如果当前的beanClass是AOP基础设施对象,那就不走AOP代理了也就是不走包装过程了,比如,你bean是一个advisor,我还代理个锤子哦
5、最最最重要的方法,wrapIfNecessary(Object bean,String beanName,Object cacheKey),判断当前bean是否有必要包装(如果是AOP基础对象,跳过,如果是切面bean,也跳过),如果没有就缓存当前的bean到advisedBeans(并发
map)返回,如果符合wrap的条件,就调用proxyFactory.getProxy()方法去拿到当前bean的代理对象然后返回
spring ioc容器刷新的12个步骤(方法):
1、 prepareRefresh() 设置启动时间、容器的激活状态、关闭状态、设置属性资源解析对象
2、 obtainFreshBeanFactory() 获取bean工厂
3、 prepareBeanFactory() 工厂配置,添加一些处理器等
4、 postProcessBeanFactory(beanFactory) 留给子容器实现的,拿到bf后做一些配置
5、 invokeBeanFactoryPostProcessors(beanFactory) 调用bf的增强器,实例化bfpp的同时,处理并往ioc容器中注册一些bd,比如处理@Configuration注解类的时候,通过@Import @Bean 等注解修饰的bean,全部处理成bd进ioc
6、 registerBeanPostProcessors(beanfactory) 注册并实例化bpp,比如AutowiredAnnotationBeanPostProcessor和CommonAnnotationBeanPostProcessor PostProcessRegistrationDelate
7、 initMessageSource() 初始化国际消息
8、 initApplicationEventMulticaster() 初始化应用事件多播器
9、 onRefresh() 留给子类扩展用的
10、registerListeners() 注册监听器,监听器最终保存道多播器中的监听器列表中
11、finishBeanFactoryInitialization() 完成bf中剩余未实例化&初始化的单例bean
12、finishRefresh() 整个ioc刷新完,还有要做一些事件发布等收尾job
AnnotationAwareAspectJAutoProxyCreator AspectJAutoProxyRegistrar --> 实例化了AnnotationAwareAspectJAutoProxyCreator实例,这个类方法不是太多,主要是就是发现候选的织入器列表,然后判断当前beanClass是不是aop基础设施对象,判断当前beanName是不是有资格的切面类
AspectJAwareAdvisorAutoProxyCreator 这个类的方法更少,也就是作用更少,对advisors进行排序、有一个比较重要的方法很吊,就是对advisors进行扩展,在其头部添加一个DefaultPointcutAdvisor对象,该对象持有一个Advice即ExposeInvocationInterceptor,这个类还有一个用途,就是判断当前beanClass和beanName是否是切面bean,如果是,方法shouldSkip()就返回true,也就是返回到调用出的结论就是,切面类无法发生AOP代理
AbstractAdvisorAutoProxyCreator 这个类的方法就多了,一般抽象类都是定义算法的,也就是模板方法,其提供了大多数和Advisor对象操作有关的方法,比如获取ioc中所有的织入器、比如获取应用在对应bean上的所advisors
再比如也提供了对advisors排序的方法,当然还有一个需要子类覆盖的空方法extendAdvisors(List<Advisor>)
AbstractAutoProxyCreator --->这个类的方法是最多的,因为它是父亲,承担的责任更大,如提供配置的方法、然后有一个方法很重要,就是wrapIfNecessary()包装bean成aop代理对象,所以这个抽象父类中还提供了createProxy功能,
总之,最终发生aop代理的bean都会在这个类中进行包装,结果很简单,但是过程很值得推敲,这就是spring的魅力啊!对了这个类还是实现了SmartInstantiationAwareBeanPostProcessor extends InstantiationAwareBeanPostProcessor