Spring源码之工厂(容器)
为什么把Spring的工厂又叫做容器呢?
工厂的责任是创建对象,但是创建完对象后还要进行存储(针对于单例的对象来讲),以供其他地方使用,这就是容器。为了能存多个对象,并能方便查找,所以Spring创建的单实例对象是通过类似map的结构来存储的。
引申一下:
为什么有些人也把tomcat叫做容器?
因为tomcat不仅要创建servelet,还要存储servelet。
我们最常用的Spring工厂是ApplicationContext(应用上下文),这其实是Spring的高级工厂,它复合了很多的功能,我们在编程的过程中,用它最方便,实际上它的很多功能被Spring提供的其他的工厂分担了。所以我们可以认为ApplicationContext是编程过程中的一个门面。
正因为它的功能太多,所以我们在分析源码的时候,如果先从它入手,会分析乱了。
这个时候,我们就要找到Spring最为核心且典型的工厂——BeanFactory。
BeanFactory
BeanFactory是接口,我们先来看下BeanFactory的实现结构图。
它们的功能是什么呢?我们选择一些重要的来介绍一下。
-
BeanFactory:Spring体系中,最底层的工厂,定义了工厂的最基本操作。比如,存或取bean;
-
HierarchicalBeanFactory:提供了父子容器管理的功能;
-
AutowireCapableBeanFactory:
-
提供了自动注入的功能;
-
还提供intinitialBean(初始化单例bean时调用其中的afterPropertieSet方法)、DisposeBean(销毁单例bean之前调用其中的destory方法)的功能;
-
-
ListableBeanFactory:可以获取相关的配置信息 ,比如constrainsBeanDefinition、getBeanNameForType等信息;
-
ConfigurableBeanFactory:提供了如下功能:
配置创建的是单实例还是多实例 (scope)、类型转换器的功能,后置处理Bean的功能;
-
DefaultListableBeanFactory:符合上述所有主要工厂能力 的一个类型;
-
XmlBeanFactory:内部有XmlBeanDefinitionReader的工具类,可以使用基于XML配置的信息,完成对象的创建;
-
ApplicationContext:集工厂功能大成的类型,编程时使用。
我们主要使用XmlBeanFactory来分析Spring工厂,之所以用它,是因为其内部有XmlBeanDefinitionReader工具类,可以读取xml的信息。
获取对象的简单代码演示:
//1. 读取XML配置文件,XML配置文件 封装 Java对象 ---> 创建工厂生产的对象
BeanFactory beanFactory = new XmlBeanFactory(new ClassPathResource("applicationContext.xml"));
//2. 从工厂容器中获得对象
User user = (User) beanFactory.getBean("u");