當一個bean的作用域設置為singleton, 那么Spring IOC容器中只會存在一個共享的bean實例,并且所有對bean的請求,只要id與該bean定義相匹配,則只會返回bean的同一實例。換言之,當把 一個bean定義設置為singleton作用域時,Spring IOC容器只會創建該bean定義的唯一實例。這個單一實例會被存儲到單例緩存(singleton cache)中,并且所有針對該bean的后續請求和引用都將返回被緩存的對象實例,這里要注意的是singleton作用域和GOF設計模式中的單例是 完全不同的,單例設計模式表示一個ClassLoader中只有一個class存在,而這里的singleton則表示一個容器對應一個bean,也就是 說當一個bean被標識為singleton時候,spring的IOC容器中只會存在一個該bean。
配置實例:
- < bean scope = "singleton" />
- < bean singleton = "true" />
prototype作用域部署的bean,每一次請求(將其注入到另一個bean中,或者以程序的方式調用容器的getBean()方法)都會 產生一個新的bean實例,相當與一個new的操作,對于prototype作用域的bean,有一點非常重要,那就是Spring不能對一個 prototype bean的整個生命周期負責,容器在初始化、配置、裝飾或者是裝配完一個prototype實例后,將它交給客戶端,隨后就對該prototype實例不 聞不問了。不管何種作用域,容器都會調用所有對象的初始化生命周期回調方法,而對prototype而言,任何配置好的析構生命周期回調方法都將不會被調 用。清除prototype作用域的對象并釋放任何prototype bean所持有的昂貴資源,都是客戶端代碼的職責。(讓Spring容器釋放被singleton作用域bean占用資源的一種可行方式是,通過使用 bean的后置處理器,該處理器持有要被清除的bean的引用。)
配置實例:
- < bean scope = "prototype" />
或者
- < beanid beanid = "role" singleton = "false" />
request表示該針對每一次HTTP請求都會產生一個新的bean,同時該bean僅在當前HTTP request內有效,配置實例:
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的實現:
- < 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請求都會產生一個新的bean,同時該bean僅在當前HTTP session內有效,配置實例:
配置實例:
和request配置實例的前提一樣,配置好web啟動文件就可以如下配置:
- < bean scope = "session" />
global session作用域類似于標準的HTTP Session作用域,不過它僅僅在基于portlet的web應用中才有意義。Portlet規范定義了全局Session的概念,它被所有構成某個 portlet web應用的各種不同的portlet所共享。在global session作用域中定義的bean被限定于全局portlet Session的生命周期范圍內。如果你在web中使用global session作用域來標識bean,那么web會自動當成session類型來使用。
配置實例:
和request配置實例的前提一樣,配置好web啟動文件就可以如下配置:
- < bean scope = "globalsession" />
6、自定義bean裝配作用域
在spring2.0中作用域是可以任意擴展的,你可以自定義作用域,甚至你也可以重新定義已有的作用域(但是你不能覆蓋singleton和 prototype),spring的作用域由接口org.springframework.beans.factory.config.Scope來定 義,自定義自己的作用域只要實現該接口即可,下面給個實例:
我們建立一個線程的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
- }
- }
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

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