上篇文章主要介绍了事务的源码:
事务有一个拦截器,先获取事务相关属性(相关属性可以在事务注解上面配置),之后再获取平台事务管理器PlatFormTransactionManager,最后执行目标方法,若正常,则获取到事务管理器,提交事务,若有异常,则获取到事务管理器,回滚此次方法。
声明式事务源码解析--- Spring源码从入门到精通(二十六)
这篇文章主要介绍beanFactoryPostProcessor源码:
一、代码实现
创建extConfig类,和myBeanFactoryPostProcessor类
/** * @author keying * @date 2021/7/15 */ @Component public class MyBeanFactoryPostProcessor implements BeanFactoryPostProcessor { public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException { System.out.println("myBeanFactoryPostProcessor。。。。。"); int count = beanFactory.getBeanDefinitionCount(); System.out.println("当前beanFactory几个 bean:" + count); String[] strings = beanFactory.getBeanDefinitionNames(); System.out.println("当前bean名称:" + Arrays.asList(strings)); } } /** * * beanPostProcessor:是bean的后置处理器,bean创建实例之后,初始化前后拦截的工作。 * beanFactoryPostProcessor:是beanFactory的后置处理器。 * 在beanFactory标准初始化之后调用:所有bean的定义已经保存加载到beanFactory,但还未创建bean实例。 * * @author keying */ @Configuration @ComponentScan("com.alibaba.ext") public class ExtConfig { @Bean("carBean") public Car car(){ return new Car(); } }
/** * @author keying * */ public class AOPTestExt { @Test public void test() { AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(ExtConfig.class); applicationContext.close(); } }
junitTest运行之后打印如下,
所以beanFactoryPostProcessor是在car对象创建之前调用的。
二、源码分析
BeanPostProcessor:bean后置处理器,是在bean创建对象之后初始化前后进行拦截工作。
BeanFactoryProcessor:beanFactory后置处理器,在所有的bean定义已经保存在beanFactory里,但还未创建bean对象之前调用。
1、ioc容器创建对象
2、Refresh()刷新容器里的invokeBeanFactoryPostProcessor()方法
如何找到beanFactoryPostProcessor并执行他们的方法?
1)、直接在beanFactory中找到所有类型是beanFactoryPostProcessor组件,并执行他们的方法。
先定义几个list,按PriorityOrdered和Ordered类分类,最后可以看到执行nonOrderedPostProcessorNames的list集合。
2)、可以看到,之前初始化bean的方法在下面,所以beanFactory在其他对象初始化前执行。