介面表示一種能力,實現了一個介面,即擁有一種能力。 BeanDefinition與Bean的關係, 就好比類與對象的關係. 類在spring的數據結構就是BeanDefinition.根據BeanDefinition得到的對象就是我們需要的Bean. 我認為理解Bean與BeanDefinition ...
介面表示一種能力,實現了一個介面,即擁有一種能力。
BeanDefinition與Bean的關係, 就好比類與對象的關係. 類在spring的數據結構就是BeanDefinition.根據BeanDefinition得到的對象就是我們需要的Bean.
我認為理解Bean與BeanDefinition是理解spring的整個架構的基礎與關鍵。我將從Bean與BeanDefinition開始慢慢撥開spring的內幕。
研究bean與BeanDefinition,我認為可以分為兩部分來循序漸進的解析。
- 一方面從定義入手:研究Bean/BeanDefinition在spring中的定義.
- 另一方面從動作(操作)入手:研究Bean/BeanDefinition的相關操作。
BeanDefinition
BeanDefinition是bean在spring中的描述,有了BeanDefinition我們就可以創建Bean,BeanDefinition是Bean在spring中的定義形態
接下來我們看看BeanDefinition的相關介面與類.
定義
- BeanDefinition介面頂級基礎介面,用來描述Bean,裡面存放Bean元數據,比如Bean類名、scope、屬性、構造函數參數列表、依賴的bean、是否是單例類、是否是懶載入等一些列信息。
向上
- BeanMetadataElement介面:BeanDefinition元數據,返回該Bean的來源
- AttributeAccessor介面:提供對BeanDefinition屬性操作能力,
向下
AbstractBeanDefinition類:抽象類統一實現了BeanDefinition定義的一部分操作,可以說是定義了BeanDefinition很多預設的屬性。 正是在AbstractBeanDefinition基礎上, Spring衍生出了一些列BeaDefinition。
這裡我們可以關註下重寫的equals(),hashcode(), toString()方法
此外initMethodName屬性,destroyMethodName 屬性, 這兩個屬性bean的生命周期有關,此處只提一句,後續講解。
接下來。我們看看從AbstractBeanDefinition上衍生出來的幾個類
RootBeanDefinition:
代表一個xml,java Config來的BeanDefinitionChildBeanDefinition:
可以讓子BeanDefinition定義擁有從父母哪裡繼承配置的能力GenericBeanDefinition:
spring2.5後註冊bean首選的是GenericBeanDefinition。GenericBeanDefinition允許動態的設置父bean.GenericBeanDefinition可以作為RootBeanDefinition與ChildBeanDefinition的替代品。- AnnotatedBeanDefinition介面:
表示註解類型BeanDefinition。有兩個重要的屬性,AnnotationMetadata,MethodMetadata分別表示BeanDefinition的註解元信息和方法元信息
實現了此介面的BeanDefinition可以獲取到註解元數據和方法元數據。 AnnotatedGenericBeanDefinition類:
表示@Configuration註解註釋的BeanDefinition類ScannedGenericBeanDefinition類:
表示@Component、@Service、@Controller等註解註釋的Bean類
操作
動作也可分為兩種:
一種是針對自身的操作: 自提提供給外部的可以操作其本身的動作
另一種是外部對BeanDefinition的操作
BeanDefinitionRegistry介面:具有增,查,刪BeanDefinition的能力。一次只能註冊一個BeanDefinition.
實現類SimpleBeanDefinitionRegistry,DefaultListableBeanFactory,GenericApplicationContext等
一般實現類里都都有一個
private final Map<String, BeanDefinition> beanDefinitionMap = new ConcurrentHashMap()來存儲BeanDefinition.
BeanDefinitionReader介面: 既可以使用BeanDefinitionRegistry構造。也可以通過loadBeanDefinitions把配置載入為多個BeanDefinition並註冊到BeanDefinitionRegistry中。
可以說是高效版本的BeanDefinitionRegistry.
實現類有
XmlBeanDefinitionReader從xml中讀取BeanDefinition;
PropertiesBeanDefinitionReader從Properties文件讀取BeanDefinitionAnnotatedBeanDefinitionReader類
對帶有註解的BeanDefinition進行註冊ClassPathBeanDefinitionScanner類:
可以掃描到@Component @Repository @Service @Controller 的BeanDefinition註冊到容器中。
其他形態
- BeanDefinitionHolder: BeanDefinition包裝類。
Bean
Bean是我們需要的對象,是我們從spring內得到的結果,也就是對象實例
定義
從定義層面看.Bean其實就是我們需要的對象.
操作
我們來看看Bean在spring有哪些操作相關的介面或類。
- SingletonBeanRegistry介面:與BeanDefinition的註冊相應的。Bean的操作也有一個類似的介面來操作Bean.SingletonBeanRegistry介面提供了對Bean的註冊,獲取,存在性判斷等功能。
- InitializingBean:對於實現 InitializingBean的Bean,它將執行 afterPropertiesSet(); 在所有的 bean 屬性被設置之後。
- InstantiationStrategy:提供 Bean實例化的策略介面,
- DisposableBean:對於 實現了DisposableBean的Bean ,它將運行 destroy()在 Spring 容器釋放該 bean 之後
- FactoryBean: 生產Bean的Bean.
其他形態
- BeanWrapper:
對Bean的包裝.BeanWrapper可以看作是一個從 BeanDefinition 到 Bean 過程中間的產物,可以稱為”低級 bean“,在一般情況下,我們不會在實際項目中用到它。BeanWrapper 是 Spring 框架中重要的組件類,它就相當於一個代理類,Spring 委托 BeanWrapper 完成 Bean 屬性的填充工作。在 bean 實例被 InstantiatioonStrategy 創建出來後,Spring 容器會將 Bean 實例通過 BeanWrapper 包裹起來,是通過 BeanWrapper.setWrappedInstance() 完成的
總結:
BeanDefinition是物料,Bean是成品,理解BeanDefinition與Bean的關係是理解spring的基礎
。
下篇分享 物料倉庫,成品倉庫,體現在“存”的操作。
歡迎大家關註我的公眾號【源碼行動】,最新個人理解及時奉送。