Spring IOC容器设计图
1. 下面这张图描述了IOC容器中的主要接口设计:
下面对接口关系做一些简要的分析,可以依据以下内容来理解这张接口设计图。
- 从接口BeanFactory到HierarchicalBeanFactory,再到ConfigurableBeanFactory,是一条主要的BeanFactory设计路径。在这条设计路径中,BeanFactoty接口定义了基本的IOC容器的规范。在这个接口定义中,包含了了getBean()这样的IOC容器的基本方法。而HierarchicalBeanFactory接口在继承了BeanFactory的基本接口之后,增加了getParentBeanFactory()接口的功能,使BeanFactory具备了双亲IOC容器的管理功能。在接下来的ConfigurableBeanFactory接口中,主要定义了一些对于BeanFactory的配置功能,比如setParentBeanFactory()设置双亲容器,通过addBeanPostProcessor()配置Bean后置处理器。通过这些接口设计的叠加,定义了BeanFactory就是简单IOC容器的基本功能。关于BeanFactory简单IOC容器的设计,我会在以后的文章中详细介绍。
2. 第二条设计主线是,以ApplicationContext应用上下文接口为核心的接口设计,这里涉及的主要接口有,从BeanFactory到ListableBeanFactory,再到我们常用的WebApplicationContext或者ConfigurableApplicationContext接口。我们常用的应用上下文基本都是WebApplicationContex或者ConfigurableApplicationContext的实现。在这个接口体系中,ListableBeanFactory和HierarchicalBeanFactory两个接口,连接BeanFactory接口定义和ApplicationContext应用上下文的接口定义。在ListableBeanFactory接口中,细化了许多BeanFactory的接口功能,比如定义了getBeanDefinitionNames()接口方法;对于HierarchicalBeanFactory接口,前面已经提及,对于ApplicationContext接口,它通过继承MessageSource,ResourceLoader,ApplicationEventPublisher接口,在BeanFactory简单IOC容器的基础上添加了许多高级容器的特性支持。
3. 这里涉及的主要是接口关系,而具体的IOC容器都是在这个接口体系下实现的,比如DefaultListableBeanFactory,这个基本的IOC容器的实现就是实现了ConfigurableBeanFactory,从而成为了一个简单IOC容器的实现。像其他容器,比如XmlBeanFactory,都是在DefaultListableBeanFactory的基础上做扩展,同样地,ApplicationContext的实现也是如此。
4. 这个接口系统是以BeanFactory和ApplicationContext为核心的,而BeanFactory又是IOC容器的最基本的接口,在ApplicationContext的设计中,一方面,可以看到它继承了BeanFactory接口体系中的ListableBeanFactory,AutowireCapableBeanFactory,HierarchicalBeanFactory等BeanFactory接口,具备了BeanFactory IOC容器的基本功能,另一方面,通过继承MessageSource,ResourceLoader,ApplicationEventPublisher这些接口,BeaFactory为ApplicationContext赋予了更高级的IOC容器的特性。对于WebApplicationContext而言,为了在Web环境中使用它,还设计了WebApplicationContext接口,而这个接口通过继承ThemeSource接口来扩充功能。
下此更新:BeanFactory容器的设计原理