Spring底层原理(二)
BeanFactory
的实现
//创建BeanFactory对象
DefaultListableBeanFactory factory = new DefaultListableBeanFactory();
//注册Bean定义对象
AbstractBeanDefinition beanDefinition = BeanDefinitionBuilder.genericBeanDefinition(SpringConfig.class)
.setScope("singleton").getBeanDefinition();
factory.registerBeanDefinition("config",beanDefinition);
for (String name : factory.getBeanDefinitionNames()) {
System.out.println(name);
}
使用AnnotationConfigUtils
为容器添加后置处理器
//给BeanFactory添加一些常用的后置处理器,对BeanFactory功能进行增强
AnnotationConfigUtils.registerAnnotationConfigProcessors(factory);
Spring自带的后置处理器
org.springframework.context.annotation.internalConfigurationAnnotationProcessor
org.springframework.context.annotation.internalAutowiredAnnotationProcessor
org.springframework.context.annotation.internalCommonAnnotationProcessor
org.springframework.context.event.internalEventListenerProcessor
org.springframework.context.event.internalEventListenerFactory
-
internalConfigurationAnnotationProcessor
:对@Configuration
与@Bean
注解进行解析处理,为BeanFactory
后置处理器 -
internalAutowiredAnnotationProcessor
:对@Autowired
注解进行解析处理,是Bean后置处理器
-
internalCommonAnnotationProcessor
:对@Resource
注解进行解析处理,是Bean后置处理器
执行BeanFactory
后置处理器
Map<String, BeanFactoryPostProcessor> factoryPostProcessorMap = factory.getBeansOfType(BeanFactoryPostProcessor.class);
for (BeanFactoryPostProcessor processor : factoryPostProcessorMap.values()) {
processor.postProcessBeanFactory(factory);
}
- 需要调用这些后置处理器的
postProcessBeanFactory
方法,这些处理器才会生效
BeanFactory
后置处理器主要功能:补充了一些bean的定义
关联Bean
与Bean
后置处理器
factory.getBeansOfType(BeanPostProcessor.class).values().forEach(factory::addBeanPostProcessor);
Bean
后置处理器:针对Bean的生命周期的各个阶段提供拓展,例如@Autowired
@Resource
…
💡BeanFactry
中的单例对象并不是预先就创建好的,而是第一次从容器中获取时才进行创建
如何将这些单例bean预实例化呢?
factory.preInstantiateSingletons();
- 该方法将所有单例对象进行预实例化
总结
beanFactory
不会做的事
- 不会主动调用
BeanFactory
后置处理器 - 不会主动添加
Bean
后置处理器 - 不会主动初始化单例
- 不会解析
beanFactory
,也不会解析${}
与#{}
bean
后置处理器会有排序的逻辑
-
AnnotationConfigUtils
在调用registerAnnotationConfigProcessors
方法后,会自动设置一个排序比较器供后续使用
//默认采用list的排序规则 public static void sort(List<?> list) { if (list.size() > 1) { list.sort(INSTANCE); } }
-
排序时会调用后置处理器的
getOrder
方法,该方法会返回一个整数,根据整数排序-
CommonAnnotationBeanPostProcessor
this.setOrder(2147483644);
-
AutowiredAnnotationBeanPostProcessor
private int order = 2147483645;
所以当
Autowired
与Resource
注解同时使用时会根据后置处理器的顺序决定谁生效 -
-
测试排序规则
ArrayList<Integer> integers = new ArrayList<>(); integers.add(2147483644); integers.add(2147483645); integers.sort(AnnotationAwareOrderComparator.INSTANCE); //[2147483644, 2147483645]
- 数字越小优先级越高,所以
@Resource
的优先级更高
- 数字越小优先级越高,所以