javascript
Spring中bean的五个作用域简介(转载)
Spring上個(gè)版本的IoC容器支持兩個(gè)不同的bean作用域(單例與原型)。
Spring 2.0改進(jìn)了這一點(diǎn),不僅提供了一些依賴于Spring部署環(huán)境(比如說,在web環(huán)境中的request和session作用域bean)的額外的作用域,而且提供了所謂的'鉤子'('hooks')(因?yàn)檎也坏礁玫谋磉_(dá))使Spring用戶可以創(chuàng)造自己的作用域。
應(yīng)該注意的是,即使單例與原型作用域beans的基本(內(nèi)在)實(shí)現(xiàn)發(fā)生了變化,上述變化對最終用戶來說是透明的...現(xiàn)有的配置不需要改變或放棄。
如何使用spring的作用域:
?
| <bean id="role" class="spring.chapter2.maryGame.Role" scope="singleton"/> |
下面分別對spring 中的作用域分別介紹一下:
?
1、singleton作用域
當(dāng)一個(gè)bean的作用域設(shè)置為singleton,那么Spring IOC容器中只會(huì)存在一個(gè)共享的bean實(shí)例,并且所有對bean的請求,只要id與該bean定義相匹配,則只會(huì)返回bean的同一實(shí)例。換言之,當(dāng)把一個(gè)bean定義設(shè)置為singleton作用域時(shí),Spring IOC容器只會(huì)創(chuàng)建該bean定義的唯一實(shí)例。這個(gè)單一實(shí)例會(huì)被存儲(chǔ)到單例緩存(singleton cache)中,并且所有針對該bean的后續(xù)請求和引用都將返回被緩存的對象實(shí)例,這里要注意的是singleton作用域和GOF設(shè)計(jì)模式中的單例是完全不同的,單例設(shè)計(jì)模式表示一個(gè)ClassLoader中只有一個(gè)class存在,而這里的singleton則表示一個(gè)容器對應(yīng)一個(gè)bean,也就是說當(dāng)一個(gè)bean被標(biāo)識為singleton時(shí)候,spring的IOC容器中只會(huì)存在一個(gè)該bean。
配置實(shí)例:
?
| <bean id="role" class="spring.chapter2.maryGame.Role" scope="singleton"/> |
?
或者
?
| <bean id="role" class="spring.chapter2.maryGame.Role" singleton="true"/> |
?
2、prototype
prototype作用域部署的bean,每一次請求(將其注入到另一個(gè)bean中,或者以程序的方式調(diào)用容器的getBean()方法)都會(huì)產(chǎn)生一個(gè)新的bean實(shí)例,相當(dāng)于一個(gè)new的操作,對于prototype作用域的bean,有一點(diǎn)非常重要,那就是Spring不能對一個(gè)prototype bean的整個(gè)生命周期負(fù)責(zé),容器在初始化、配置、裝飾或者是裝配完一個(gè)prototype實(shí)例后,將它交給客戶端,隨后就對該prototype實(shí)例不聞不問了。不管何種作用域,容器都會(huì)調(diào)用所有對象的初始化生命周期回調(diào)方法,而對prototype而言,任何配置好的析構(gòu)生命周期回調(diào)方法都將不會(huì)被調(diào)用。清除prototype作用域的對象并釋放任何prototype bean所持有的昂貴資源,都是客戶端代碼的職責(zé)。(讓Spring容器釋放被singleton作用域bean占用資源的一種可行方式是,通過使用bean的后置處理器,該處理器持有要被清除的bean的引用。)
配置實(shí)例:
?
| <bean id="role" class="spring.chapter2.maryGame.Role" scope="prototype"/> |
?
或者
?
| <beanid="role" class="spring.chapter2.maryGame.Role" singleton="false"/> |
3、request
?
request表示該針對每一次HTTP請求都會(huì)產(chǎn)生一個(gè)新的bean,同時(shí)該bean僅在當(dāng)前HTTP request內(nèi)有效,配置實(shí)例:
request、session、global session使用的時(shí)候,首先要在初始化web的web.xml中做如下配置:
如果你使用的是Servlet 2.4及以上的web容器,那么你僅需要在web應(yīng)用的XML聲明文件web.xml中增加下述ContextListener即可:
?
| <web-app> ... <listener> <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class> </listener> ... </web-app> |
?
如果是Servlet2.4以前的web容器,那么你要使用一個(gè)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的作用域了:
?
| <bean id="role" class="spring.chapter2.maryGame.Role" scope="request"/> |
?
4、session
session作用域表示該針對每一次HTTP請求都會(huì)產(chǎn)生一個(gè)新的bean,同時(shí)該bean僅在當(dāng)前HTTP session內(nèi)有效,配置實(shí)例:
配置實(shí)例:
和request配置實(shí)例的前提一樣,配置好web啟動(dòng)文件就可以如下配置:
?
| <bean id="role" class="spring.chapter2.maryGame.Role" scope="session"/> |
?
5、global session
global session作用域類似于標(biāo)準(zhǔn)的HTTP Session作用域,不過它僅僅在基于portlet的web應(yīng)用中才有意義。Portlet規(guī)范定義了全局Session的概念,它被所有構(gòu)成某個(gè)portlet web應(yīng)用的各種不同的portlet所共享。在global session作用域中定義的bean被限定于全局portlet Session的生命周期范圍內(nèi)。如果你在web中使用global session作用域來標(biāo)識bean,那么,web會(huì)自動(dòng)當(dāng)成session類型來使用。
配置實(shí)例:
和request配置實(shí)例的前提一樣,配置好web啟動(dòng)文件就可以如下配置:
?
| <bean id="role" class="spring.chapter2.maryGame.Role" scope="global session"/> |
?
6、自定義bean裝配作用域
在spring 2.0中作用域是可以任意擴(kuò)展的,你可以自定義作用域,甚至你也可以重新定義已有的作用域(但是你不能覆蓋singleton和prototype),spring的作用域由接口org.springframework.beans.factory.config.Scope來定義,自定義自己的作用域只要實(shí)現(xiàn)該接口即可,下面給個(gè)實(shí)例:
我們建立一個(gè)線程的scope,該scope在表示一個(gè)線程中有效,代碼如下:
?
| publicclass MyScope implements Scope ...{ privatefinal ThreadLocal threadScope = new ThreadLocal() ...{ protected Object initialValue() ...{ returnnew HashMap(); } }; public Object get(String name, ObjectFactory objectFactory) ...{ Map scope = (Map) threadScope.get(); Object object = scope.get(name); if(object==null) ...{ object = objectFactory.getObject(); scope.put(name, object); } return object; } public Object remove(String name) ...{ Map scope = (Map) threadScope.get(); return scope.remove(name); } publicvoid registerDestructionCallback(String name, Runnable callback) ...{ } public String getConversationId() ...{ // TODO Auto-generated method stub returnnull; } } |
轉(zhuǎn)載于:https://www.cnblogs.com/zhouxiansheng/p/3954707.html
總結(jié)
以上是生活随笔為你收集整理的Spring中bean的五个作用域简介(转载)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 数字图像的5种增强处理
- 下一篇: 数字的空洞 水 南邮NOJ 1071