Spring的基础结构和核心接口
目录
1、BeanDefinition
2、BeanDefinitionReader
3、BeanDefinitionRegistry
4、BeanFactory
5、ApplicationContext
6、BeanPostProcessor
7、BeanFactoryPostProcessor
8、BeanDefinitionRegistryPostProcessor
9、总结
一、BeanDefinition
BeanDefinition 描述了一个Bean的实例定义信息,它记录了Bean的相关信息,并且可以设置以及获取Bean的内容,例如:Bean类名,Bean的作用域,Bean是否懒加载,,
初始化方法名称,销毁方法名称,是否单例,是否原型,Bean属性值等等,直至根据BeanDefinition 生成Bean,可以说在Bean的管理中起到至关重要的作用

二、BeanDefinitionReader
看名称顾名思义是用来读取Bean的定义信息生成BeanDefinition 并注册:
-
XmlBeanDefinitionReader: 用来解析Xml读取信息生成BeanDefinition并注册
-
AnnotatedBeanDefinitionReader: 读取注解生成BeanDefinition并注册
-
ClassPathBeanDefinitionScanner: 扫描类路径生成BeanDefinition并注册
注意:这里的注册要分清楚不是注册Bean,可以理解为保存bean的BeanDefination到BeanDefinitionRegistry中提供给后续的Bean生成使用

三、BeanDefinitionRegistry
看名称是BeanDefinition注册的接口,主要是对BeanDefinition做一个管理操作,例如注册、移除、获取等,实现了AliasRegistry,即还可以对Bean的别名进行管理

注意:DefaultListableBeanFactory即是一个Bean的工厂同时也可以完成BeanDefination注册,这个是一个很重要的角色
四、BeanFactory是Spring容器的顶层接口
BeanFactory是Spring容器的顶层接口,提供了对Bean的基本操作,其实现类根据其特点基本实现了对Bean的各种操作;

从BeanFactory来看:
-
HierarchicalBeanFactory: 层次结构的BeanFactory提供两个方法getParentBeanFactory获取当前BeanFactory的父类,containsLocalBean当前BeanFactory是否包含指定名称的bean
-
ListableBeanFactory: 可罗列的BeanFactory,这里的可罗列意味着此BeanFactory提供类似于
Map<String, T> getBeansOfType (@Nullable Class type)这种获取满足条件的一系列bean的功能 -
AutowireCapableBeanFactory: 具备自动装备功能的BeanFactory,提供了createBean实例化,属性填充,回调生命周期的创建bean,autowire自动装配bean,initializeBean 回调相关初始化方法等方法
-
ConfigurableBeanFactory : 可配置的BeanFactory,提供了setParentBeanFactory ,setBeanClassLoader,addBeanPostProcessor等配置bean工厂的方法
-
ConfigurableListableBeanFactory: 实现了ListableBeanFactory ,AutowireCapableBeanFactory ,ConfigurableBeanFactory,具备其他三者的功能的同时,还提供了ignoreDependencyType 忽略给定依赖类型的自动装配,registerResolvableDependency 注册指定类型的依赖使用指定的对象进行注入等功能
五、ApplicationContext

这个可以说是Spring的容器,总体来说也是一个BeanFactory,其实是对BeanFactory功能的更多扩展:
-
EnvironmentCapable: 提供获取Environment的能力
-
ResourceLoader: 用于加载资源(例如类路径或文件系统资源)的策略接口,根据路径获取资源包装成Resource
-
ResourcePatternResolver: ResourceLoader的子接口,提供根据路径匹配获取资源的能力
-
ApplicationEventPublisher : 事件发送接口
-
MessageSource: 用于解析消息的策略接口,用于实现国际化
两个重要的实现类:
-
AnnotationConfigApplicationContext: 基于注解包路径扫描的容器上下文,通过注解扫描来完成BeanDefinition的注册
-
ClassPathXmlApplicationContext: 基于类路径下xml文件的Spring应用程序上下文,通过解析类路径下的xml来完成BeanDefinition的注册
六、BeanPostProcessor
Bean后置处理器(重中之重!!!),内部有两个方法:
-
postProcessBeforeInitialization: Bean初始化前调用
-
postProcessAfterInitialization: Bean初始化后调用
源代码如下:

另一个实现了它的拓展接口InstantiationAwareBeanPostProcessor内部新增了4个方法:
-
postProcessBeforeInstantiation:Bean实例化前调用
-
postProcessAfterInstantiation:Bean实例化后调用
-
postProcessProperties:Bean属性注入的时候调用
-
postProcessPropertyValues:Bean属性注入的时候调用
源代码如下:

列举两个与我们平时息息相关的BeanPostProcessor:
-
AutowiredAnnotationBeanPostProcessor: 对@Autowired注解标识的做属性注入(此注解原理),还有其他注解例如: @Value,@Lookup,@Inject
-
CommonAnnoatationBeanPostProcessor: 与上面那个一样,但主要处理@Resource注解
七、BeanFactoryPostProcessor
源代码如下:

名称跟上面那位大哥很像,这个也是后置处理器,但是是BeanFactory的后置处理器,对BeanFactory相关信息可以做一些修改
使用目的:在BeanFactory标准初始化之后调用,用来定制和修改BeanFactory内的内容;
八、BeanDefinitionRegistryPostProcessor

继承了上面那位大哥,同样会在BeanFactory之后调用,但是内部多了个对BeanDefination处理的方法,该方法可以对BeanFactory中的BeanDefination做一次后置的统一处理,
该方法执行顺序在postProcessBeanFactory之前
比如@Configuration注解的底层原理就是通过实现 BeanDefinitionRegistryPostProcessor接口,然后扫描并生成BeanDefination并注册的,具体的实现类是ConfigurationClassPostProcessor
九、总结
上面的一些核心接口是不是都看懵逼了,不需要记得特别清楚,只需要知道个大概就行了:
-
1、解析Xml配置或者扫描注解生成BeanDefination加入到BeanFactory,
-
2、BeanDefinitionRegistryPostProcessor对加入到BeanFactory的BeanDefination可以做增删改查操作,
-
3、BeanFactoryPostProcessor可以对BeanFactory后置修改操作,
-
4、然后会把BeanPostProcessor注册到BeanFactory中,
-
5、最后根据BeanDefination生成Bean,在生成过程中BeanPostProcessor会起到作用
上面几个核心大概的执行顺序如下:


浙公网安备 33010602011771号