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方法,该方法会返回一个整数,根据整数排序-  
CommonAnnotationBeanPostProcessorthis.setOrder(2147483644); -  
AutowiredAnnotationBeanPostProcessorprivate int order = 2147483645; 
所以当
Autowired与Resource注解同时使用时会根据后置处理器的顺序决定谁生效 -  
 -  
测试排序规则
ArrayList<Integer> integers = new ArrayList<>(); integers.add(2147483644); integers.add(2147483645); integers.sort(AnnotationAwareOrderComparator.INSTANCE); //[2147483644, 2147483645]- 数字越小优先级越高,所以
@Resource的优先级更高 
 - 数字越小优先级越高,所以
 

















![[黑马程序员SpringBoot2]——基础篇1](https://img-blog.csdnimg.cn/323fef01b1514cd2899fc57dab737a93.png)
