Spring的Ioc容器其實就是一個bean的關係網,依賴於core,bean,context三個組件來構建的。在spring中最核心的就是對於bean的管理。而bean又依託於咱們的容器。本文將從頂層分析一下spring中beanFactory的具體建立過程,爲後續的bean的生命週期提供一個基礎。java
BeanFactory的繼承體系spring
(上述三個類的子類體系小夥伴們能夠本身對着源碼看下,實在太多)設計模式
看下上圖中最底層的DefaultListableBeanFactory類的定義:函數
public class DefaultListableBeanFactory extends AbstractAutowireCapableBeanFactory implements ConfigurableListableBeanFactory, BeanDefinitionRegistry, Serializable 複製代碼
這個其實就是BeanFactory的默認實現類,它直接或者間接的實現了全部的接口。其實在看spring源碼的時候都會遇到相似的設計模式,對於某一個具體的功能,一般都會定義不少層的接口,層層包裝,層層委託。這種作法的好處就是,對於不一樣的場合都會有特定的接口;這樣一來就能夠在spring內部對對象的傳遞和轉化操做都會有一些訪問限制。this
例如ListableBeanFactory接口表示這些Bean是可列表的,而HierarchicalBeanFactory表示的是這些Bean是有繼承關係的,也就是每一個Bean有可能有父Bean。AutowireCapableBeanFactory接口定義Bean的自動裝配規則。這四個接口共同定義了Bean的集合、Bean之間的關係、以及Bean行爲。spa
BeanFactory的建立debug
在以前的文章中說過了容器的刷新過程。BeanFactory的建立也在wac.refresh()方法中。具體看下究竟是經過哪些子類來完成的:設計
// 通知子類刷新內部的bean工廠。
ConfigurableListableBeanFactory beanFactory = obtainFreshBeanFactory();
複製代碼
1.AbstractApplicationContext中的obtainFreshBeanFactorycode
下面是obtainFreshBeanFactory的方法邏輯:cdn
protected ConfigurableListableBeanFactory obtainFreshBeanFactory() {
//這個是具體建立的方法,由子類實現
refreshBeanFactory();
//獲取BeanFactory實例對象(ConfigurableListableBeanFactory類型的)
ConfigurableListableBeanFactory beanFactory = getBeanFactory();
if (logger.isDebugEnabled()) {
logger.debug("Bean factory for " + getDisplayName() + ": " + beanFactory);
}
return beanFactory;
}
複製代碼
refreshBeanFactory並未有具體的實現邏輯,這個方法主要是經過委託給子類的refreshBeanFactory方法來實現,在AbstractApplicationContext中refreshBeanFactory是一個抽象模板方法:
protected abstract void refreshBeanFactory() throws BeansException, IllegalStateException;
複製代碼
2.refreshBeanFactory方法(AbstractRefreshableApplicationContext類中):
下面只註釋與beanFactory建立相關的代碼
protected final void refreshBeanFactory() throws BeansException {
//是否已經有BeanFactory了
if (hasBeanFactory()) {
//銷燬原有的Bean
destroyBeans();
//關閉工廠
closeBeanFactory();
}
try {
//建立一個新的beanFactory
DefaultListableBeanFactory beanFactory = createBeanFactory();
beanFactory.setSerializationId(getId());
customizeBeanFactory(beanFactory);
loadBeanDefinitions(beanFactory);
synchronized (this.beanFactoryMonitor) {
this.beanFactory = beanFactory;
}
}
catch (IOException ex) {
throw new ApplicationContextException("I/O error parsing bean definition
source for " + getDisplayName(), ex);
}
}
複製代碼
這個方法是實現執行這個上下文的底層bean工廠的實際刷新,若是有的話以前有BeanFactory存在,則關閉之前的bean工廠。併爲上下文生命週期的下一個階段初始化一個新鮮的bean工廠。
3.createBeanFactory(AbstractRefreshableApplicationContext類中)
protected DefaultListableBeanFactory createBeanFactory() {
return new DefaultListableBeanFactory(getInternalParentBeanFactory());
}
複製代碼
這個方法就是爲當前上下文建立一個內部的bean工廠。每次調用refresh()方法是都會建立嘗試建立。默認實現是建立一個DefaultListableBeanFactory。並經過getInternalParentBeanFactory()獲取內部bean工廠來做爲父級bean工廠。能夠在子類中重寫,例如自定義DefaultListableBeanFactory的設置。
getInternalParentBeanFactory(AbstractApplicationContext類中)
protected BeanFactory getInternalParentBeanFactory() {
return (getParent() instanceof ConfigurableApplicationContext) ?
((ConfigurableApplicationContext) getParent()).getBeanFactory() : getParent();
}
複製代碼
4.DefaultListableBeanFactory的構造函數
/** * 經過給定的父類建立一個新的DefaultListableBeanFactory容器 * @param parentBeanFactory the parent BeanFactory */
public DefaultListableBeanFactory(BeanFactory parentBeanFactory) {
super(parentBeanFactory);
}
複製代碼
super(parentBeanFactory)調用的是AbstractAutowireCapableBeanFactory的構造函數
/** * 經過給定的父類構建新的AbstractAutowireCapableBeanFactory * @param parentBeanFactory parent bean factory, or {@code null} if none */
public AbstractAutowireCapableBeanFactory(BeanFactory parentBeanFactory) {
this();
//設置父工廠
setParentBeanFactory(parentBeanFactory);
}
複製代碼
this(),仍是AbstractAutowireCapableBeanFactory的構造函數:
/** * 構建一個新的AbstractAutowireCapableBeanFactory. */
public AbstractAutowireCapableBeanFactory() {
super();
ignoreDependencyInterface(BeanNameAware.class);
ignoreDependencyInterface(BeanFactoryAware.class);
ignoreDependencyInterface(BeanClassLoaderAware.class);
}
複製代碼
super() ; AbstractBeanFactory的構造函數
/** * 構建一個新的AbstractBeanFactory. */
public AbstractBeanFactory() {
}
複製代碼