知识边界
BeanFactory家族
衍生点
- 完整的初始化方法和它们的标准顺序是
- ObjectProvider
- Metadata
- BeanExpressionResolver
- SingletonBeanRegistry
- DependencyDescriptor
- BeanDefinitionRegistry
- ContextTypeMatchClassLoader
BeanFactory类图
BeanFactory
访问spring bean 容器的核心接口,它是访问bean容器的基本的窗口。进一步的接口 例如ListableBeanFactory和ConfigurableBeanFactory有其具体的目的。这个接口将会被持有一定数量的被一个String类型的名字唯一标识的bean 定义的对象实例化。对于bean定义,工厂将会返回原型的bean定义或者单例的bean定义。哪一种类型的bean定义的实例将会被返回取决于配置,接口也是一样的。自从Spring2.0以后,很多Scope在具体的应用上下文中都是可用的。很多时候使用依赖注入比依赖查找更加好。Spring依赖注入的实现是依赖于BeanFactory和他的子类。
正常来说BeanFactory加载bean定义主要通过xml和注解的形式。但是,实现可以简单地返回它在必要时直接在Java代码中创建的Java对象。对于如何存储这些定义没有限制:LDAP、RDBMS、XML、属性文件等。bean之间的引用(依赖注入)也是被支持的。和ListableBeanFactory里面的方法不同,所有的在HierarchicalBeanFactory里面的方法总会检查父类方法。如果当前类在这个实例中没有被发现,那么它的父类对象就会被访问。在这种工厂中bean是可以被覆盖的。Bean工厂实现应该尽可能支持标准的Bean生命周期接口。完整的初始化方法和它们的标准顺序是:
BeanNameAware's {@code setBeanName}
BeanClassLoaderAware's {@code setBeanClassLoader}
BeanFactoryAware's {@code setBeanFactory}
EnvironmentAware's {@code setEnvironment}
EmbeddedValueResolverAware's {@code setEmbeddedValueResolver}
ResourceLoaderAware's {@code setResourceLoader}
(only applicable when running in an application context)
ApplicationEventPublisherAware's {@code setApplicationEventPublisher}
(only applicable when running in an application context)
MessageSourceAware's {@code setMessageSource}
(only applicable when running in an application context)
ApplicationContextAware's {@code setApplicationContext}
(only applicable when running in an application context)
ServletContextAware's {@code setServletContext}
(only applicable when running in a web application context)
{@code postProcessBeforeInitialization} methods of BeanPostProcessors
InitializingBean's {@code afterPropertiesSet}
a custom init-method definition
{@code postProcessAfterInitialization} methods of BeanPostProcessors
HierarchicalBeanFactory
是BeanFactory的一个子类,表示这种类是支持父子关系的。在ConfigurableBeanFactory接口中可以找到bean工厂对应的{@code setParentBeanFactory}方法,该方法允许以可配置的方式设置父类。
AutowireCapableBeanFactory
BeanFactory接口的扩展支持自动注入。如果他们希望为现有的bean实例公开此功能。这个BeanFactory的子接口并不意味这在普通的Application接口中被使用。我们经常把他和ListableBeanFactory一起使用。其他框架的集成代码可以利用这个接口连接和填充Spring没有控制的现有bean实例。例如,这对于WebWork操作和Tapestry页面对象特别有用。
特别的是 这个接口并没有被ApplicationContext继承,因为Application很少使用它。即便如此,我们也可以通过ApplicationContext#getAutowireCapableBeanFactory()方法获取它。
您也可以实现BeanFactoryAware接口,它甚至在应用程序上下文中运行时也公开内部的BeanFactory,以获得对AutowireCapableBeanFactory的访问:只需将传入的BeanFactory转换为AutowireCapableBeanFactory。
ORIGINAL_INSTANCE_SUFFIX
初始化现有bean实例时,“原始实例”约定的后缀:附加到完全限定的bean类名,例如“com.mypackage.MyClass”。,以强制返回给定的实例,即没有代理等。
ListableBeanFactory
一种可以枚举bean实例的BeanFactory接口的实现,而不是通过名字一个一个的来查找。所有预加载他们bean实例的工厂可能实现了这个接口。
如果这个工厂是HierarchicalBeanFactory工厂 他不会获取父类的bean定义,使用BeanFactoryUtils可以去获取父类的bean定义。
这个接口里面的方法只会考虑当前工厂的bean实例,他会忽略其他工厂注册的单例,这意味着像ConfigurableBeanFactory实例的registerSingleton方法不会被当前工厂获取。当然除了getBeanNamesOfType和getBeansOfType方法。当然 BeanFactory的getBean方法也允许透明地访问这些特殊的bean。然而在一些特殊的场景下,无论如何,所有bean都将由外部bean定义定义,大多数应用不需要担心这一点的不同。
除了getBeanDefinitionCount和containsBeanDefinition 其他的方法并不会被频繁的调用
ConfigurableBeanFactory
配置接口将由大多数bean工厂实现,除了BeanFactory提供的方法外还提供配置BeanFactory的方法。这个bean工厂接口不适合在普通的应用程序代码中使用:坚持使用{@link org.springframework.bean .factory。BeanFactory}或{@org.springframework.beans.factory。ListableBeanFactory}为典型的需要。这个扩展接口只是为了允许框架内部即插即用,以及对bean工厂配置方法的特殊访问。
ConfigurableListableBeanFactory
对于可枚举的Bean工厂提供了可配置话的接口,它提供了分析和修改bean定义的功能以及预加载单例的bean实例。
这个类不是用户直接使用的 一般只是框架内部使用的。
AbstractBeanFactory
BeanFactory的抽象基类,提供了完整的ConfigurableBeanFactory标准API的能力。不假设有一个可列表的bean工厂:因此也可以用作从一些后端资源(其中bean定义访问是一个昂贵的操作)获取bean定义的bean工厂实现的基类。这个类通过他的基类DefaultSingletonBeanRegistry提供了一个简单的缓存,这些缓存包括原型单例的bean定义,从子定义中合并而来的bean定义。此外,它还可以通过实现HierarchicalBeanFactory接口来管理父类的bean。被子类实现的主要方法是getBeanDefinition和createBean。检索给定bean名称的bean定义并为给定bean定义创建bean实例。具体的实现操作可以查看DefaultListableBeanFactory和AbstractAutowireCapableBeanFactory。
AbstractAutowireCapableBeanFactory
实现bean创建的抽象的子类,由RootBeanDefinition类指定的全部功能。实现了AutowireCapableBeanFactory接口 并且实现了父类的createBean。提供了bean的创建 依赖注入 实例化。处理运行时的bean依赖,解决管理集合,调用初始化方法。支持通过名称匹配属性和构造方法,通过类型匹配属性。由子类实现的主要的模板方法是resolveDependency,用来通过类型注入。
子类主要实现的是resolveDependency方法用来通过类型自动注入。
特别注意的是当前工厂并没有实现bean定义的注册功能。