一分鐘掌握Spring中bean的生命周期!
Spring 中bean 的生命周期短暫嗎?
在spring中,從BeanFactory或ApplicationContext取得的實例為Singleton,也就是預(yù)設(shè)為每一個Bean的別名只能維持一個實例,而不是每次都產(chǎn)生一個新的對象使用Singleton模式產(chǎn)生單一實例,對單線程的程序說并不會有什么問題,但對于多線程的程序,就必須注意安全(Thread-safe)的議題,防止多個線程同時存取共享資源所引發(fā)的數(shù)據(jù)不同步問題。
然而在spring中 可以設(shè)定每次從BeanFactory或ApplicationContext指定別名并取得Bean時都產(chǎn)生一個新的實例:例如:
在spring中,singleton屬性默認(rèn)是true,只有設(shè)定為false,則每次指定別名取得的Bean時都會產(chǎn)生一個新的實例
一個Bean從創(chuàng)建到銷毀,如果是用BeanFactory來生成,管理Bean的話,會經(jīng)歷幾個執(zhí)行階段(如圖1.1):

1:Bean的建立:
容器尋找Bean的定義信息并將其實例化。
2:屬性注入:
使用依賴注入,Spring按照Bean定義信息配置Bean所有屬性
3:BeanNameAware的setBeanName():
如果Bean類有實現(xiàn)org.springframework.beans.BeanNameAware接口,工廠調(diào)用Bean的setBeanName()方法傳遞Bean的ID。
4:BeanFactoryAware的setBeanFactory():
如果Bean類有實現(xiàn)org.springframework.beans.factory.BeanFactoryAware接口,工廠調(diào)用setBeanFactory()方法傳入工廠自身。
5:BeanPostProcessors的ProcessBeforeInitialization()
如果有org.springframework.beans.factory.config.BeanPostProcessors和Bean關(guān)聯(lián),那么其postProcessBeforeInitialization()方法將被將被調(diào)用。
6:initializingBean的afterPropertiesSet():
如果Bean類已實現(xiàn)org.springframework.beans.factory.InitializingBean接口,則執(zhí)行他的afterProPertiesSet()方法
7:Bean定義文件中定義init-method:
可以在Bean定義文件中使用"init-method"屬性設(shè)定方法名稱例如:
如果有以上設(shè)置的話,則執(zhí)行到這個階段,就會執(zhí)行initBean()方法
8:BeanPostProcessors的ProcessaAfterInitialization()
如果有任何的BeanPostProcessors實例與Bean實例關(guān)聯(lián),則執(zhí)行BeanPostProcessors實例的ProcessaAfterInitialization()方法
此時,Bean已經(jīng)可以被應(yīng)用系統(tǒng)使用,并且將保留在BeanFactory中知道它不在被使用。有兩種方法可以將其從BeanFactory中刪除掉(如圖1.2):

1:DisposableBean的destroy()
在容器關(guān)閉時,如果Bean類有實現(xiàn)org.springframework.beans.factory.DisposableBean接口,則執(zhí)行他的destroy()方法
2:Bean定義文件中定義destroy-method
在容器關(guān)閉時,可以在Bean定義文件中使用"destroy-method"屬性設(shè)定方法名稱,例如:
如果有以上設(shè)定的話,則進行至這個階段時,就會執(zhí)行destroy()方法,如果是使用ApplicationContext來生成并管理Bean的話則稍有不同,使用ApplicationContext來生成及管理Bean實例的話,在執(zhí)行BeanFactoryAware的setBeanFactory()階段后,若Bean類上有實現(xiàn)org.springframework.context.ApplicationContextAware接口,則執(zhí)行其setApplicationContext()方法,接著才執(zhí)行BeanPostProcessors的ProcessBeforeInitialization()及之后的流程。
【編輯推薦】