javascript
Spring源码分析-深入理解生命周期之BeanFactoryProcessor
生命周期之BeanFactoryPostProcessor
先來看看bean的生命周期。對于熟悉spring 的朋友來說,bean的生命周期并不陌生。它可以在bean加載,bean初始化的過程中加入我們自己的邏輯。并且這樣體現(xiàn)了spring開放式的設(shè)計。先來看看生命周期的圖:
今天我們要介紹的是生命周期中的BeanFactoryPostProcessor,那這個接口的作用是啥呢?它可以對已經(jīng)加載好的BeanDefinition進行處理。Spring IOC 容許BeanFactoryPostProcessor 在容器實際實例化任何bean之前讀取配置的元數(shù)據(jù)。有過Spring使用經(jīng)驗的人對 ${property} 這樣的表達式肯定很熟悉。它就是對配置信息進行替換。這樣使得配置解耦出來。而具體的邏輯就是在BeanFactoryPostProcessor相關(guān)的實現(xiàn)類的postProcessBeanFactory方法中實現(xiàn)的。
具體實現(xiàn)邏輯本文不介紹。可以看看BeanFactoryPostProcessor接口的幾個實現(xiàn)類(比如PropertyPlaceholderConfigurer)。
今天我們拋出一個疑問:既然BeanFactoryPostProcessor是在Bean加載完畢后,Bean初始化完畢前起作用的。那我們?nèi)绻趚ml配置文件中自定義一個BeanFactoryPostProcessor實現(xiàn)類,按照道理來說這個實現(xiàn)類都沒有初始化,是怎么起作用的?
先拋出答案:這個是特殊的bean,它在其他普通bean之前實例化前真的被實例化了。并且如果我們使用BeanFactory而不是用ApplicationContext,那么配置的BeanFactoryPostProcessor實現(xiàn)類不會生效,并且BeanPostProcessor也不會生效。
分析:
原因在于AbstractApplicationContext的 refresh方法中:
這個invokeBeanFactoryPostProcessors 剛好對BeanFactoryPostProcessor實現(xiàn)類進行了實例化,并且進行激活調(diào)用。
進去看看:
可以發(fā)現(xiàn),源碼中有很多getBean方法,這個正是實例化BeanFactoryPostProcessor的方法。
并且invokeBeanFactoryPostProcessors方法正是對invokeBeanFactoryPostProcessor實現(xiàn)類進行了激活,并對BeanDefinition進行了更改。
可以看到這個for循環(huán)里對BeanFactoryPostProcessor實現(xiàn)類進行了調(diào)用。
總結(jié):本文開頭的圖只是ApplicationContext對應(yīng)的生命周期,并不是BeanFactory對應(yīng)的bean的生命周期。因為我在BeanFactory實現(xiàn)中沒有找到BeanFactoryPostProcessor相應(yīng)的實現(xiàn)邏輯。題外話,而且對于BeanPostProcessor來說spring容器啟動只是注冊實例化了BeanPostProcessor并沒有調(diào)用,而是容器啟動的末尾,對其他bean 進行g(shù)etBean時,才會調(diào)用到這些BeanPostProcessor
心得:以前對Bean生命周期只是死記硬背,現(xiàn)在時豁然開朗。不需要死記硬背的,后面將會介紹bean生命周期其他的過程。
總結(jié)
以上是生活随笔為你收集整理的Spring源码分析-深入理解生命周期之BeanFactoryProcessor的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux环境中,top命令中,对com
- 下一篇: Re:从零开始的Spring Sessi