當(dāng)一個bean的作用域設(shè)置為singleton, 那么Spring IOC容器中只會存在一個共享的bean實(shí)例,并且所有對bean的請求,只要id與該bean定義相匹配,則只會返回bean的同一實(shí)例。換言之,當(dāng)把 一個bean定義設(shè)置為singleton作用域時,Spring IOC容器只會創(chuàng)建該bean定義的唯一實(shí)例。這個單一實(shí)例會被存儲到單例緩存(singleton cache)中,并且所有針對該bean的后續(xù)請求和引用都將返回被緩存的對象實(shí)例,這里要注意的是singleton作用域和GOF設(shè)計模式中的單例是 完全不同的,單例設(shè)計模式表示一個ClassLoader中只有一個class存在,而這里的singleton則表示一個容器對應(yīng)一個bean,也就是 說當(dāng)一個bean被標(biāo)識為singleton時候,spring的IOC容器中只會存在一個該bean。
配置實(shí)例:
- < bean scope = "singleton" />
- < bean singleton = "true" />
prototype作用域部署的bean,每一次請求(將其注入到另一個bean中,或者以程序的方式調(diào)用容器的getBean()方法)都會 產(chǎn)生一個新的bean實(shí)例,相當(dāng)與一個new的操作,對于prototype作用域的bean,有一點(diǎn)非常重要,那就是Spring不能對一個 prototype bean的整個生命周期負(fù)責(zé),容器在初始化、配置、裝飾或者是裝配完一個prototype實(shí)例后,將它交給客戶端,隨后就對該prototype實(shí)例不 聞不問了。不管何種作用域,容器都會調(diào)用所有對象的初始化生命周期回調(diào)方法,而對prototype而言,任何配置好的析構(gòu)生命周期回調(diào)方法都將不會被調(diào) 用。清除prototype作用域的對象并釋放任何prototype bean所持有的昂貴資源,都是客戶端代碼的職責(zé)。(讓Spring容器釋放被singleton作用域bean占用資源的一種可行方式是,通過使用 bean的后置處理器,該處理器持有要被清除的bean的引用。)
配置實(shí)例:
- < bean scope = "prototype" />
或者
- < beanid beanid = "role" singleton = "false" />
request表示該針對每一次HTTP請求都會產(chǎn)生一個新的bean,同時該bean僅在當(dāng)前HTTP request內(nèi)有效,配置實(shí)例:
request、session、global session使用的時候首先要在初始化web的web.xml中做如下配置:
- ...
- < listener-class > org.springframework.web.context.request.RequestContextListener </ listener-class >
- </ listener >
- ...
- </ web-app >
- ,如果是Servlet2.4以前的web容器,那么你要使用一個javax.servlet.Filter的實(shí)現(xiàn):
- < web-app >
- ..
- < filter >
- < filter-name > requestContextFilter </ filter-name >
- < filter-class > org.springframework.web.filter.RequestContextFilter </ filter-class >
- </ filter >
- < filter-mapping >
- < filter-name > requestContextFilter </ filter-name >
- < url-pattern > /* </ url-pattern >
- </ filter-mapping >
- </ web-app >
- < bean scope = "request" />
session作用域表示該針對每一次HTTP請求都會產(chǎn)生一個新的bean,同時該bean僅在當(dāng)前HTTP session內(nèi)有效,配置實(shí)例:
配置實(shí)例:
和request配置實(shí)例的前提一樣,配置好web啟動文件就可以如下配置:
- < bean scope = "session" />
global session作用域類似于標(biāo)準(zhǔn)的HTTP Session作用域,不過它僅僅在基于portlet的web應(yīng)用中才有意義。Portlet規(guī)范定義了全局Session的概念,它被所有構(gòu)成某個 portlet web應(yīng)用的各種不同的portlet所共享。在global session作用域中定義的bean被限定于全局portlet Session的生命周期范圍內(nèi)。如果你在web中使用global session作用域來標(biāo)識bean,那么web會自動當(dāng)成session類型來使用。
配置實(shí)例:
和request配置實(shí)例的前提一樣,配置好web啟動文件就可以如下配置:
- < bean scope = "globalsession" />
6、自定義bean裝配作用域
在spring2.0中作用域是可以任意擴(kuò)展的,你可以自定義作用域,甚至你也可以重新定義已有的作用域(但是你不能覆蓋singleton和 prototype),spring的作用域由接口org.springframework.beans.factory.config.Scope來定 義,自定義自己的作用域只要實(shí)現(xiàn)該接口即可,下面給個實(shí)例:
我們建立一個線程的scope,該scope在表示一個線程中有效,代碼如下:
- public class MyScope implements Scope{
- privatefinalThreadLocalthreadScope= new ThreadLocal(){
- protected ObjectinitialValue(){
- returnnewHashMap();
- }
- };
- public Objectget(Stringname,ObjectFactoryobjectFactory){
- Mapscope=(Map)threadScope.get();
- Objectobject=scope.get(name);
- object=objectFactory.getObject();
- scope.put(name,object);
- }
- }
- public Objectremove(Stringname){
- Mapscope=(Map)threadScope.get();
- return scope.remove(name);
- }
- publicvoidregisterDestructionCallback(Stringname,Runnablecallback){
- }
- public StringgetConversationId(){
- //TODOAuto-generatedmethodstub
- }
- }
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
