標籤:work 標頭檔 ade htm XML com 方法 load 操作
摘自 http://www.cnblogs.com/qq78292959/p/3716827.html
今天研究了一下scope的範圍。預設是單例模式,即scope="singleton"。另外scope還有prototype、request、session、global session範圍。scope="prototype"多例。再配置bean的範圍時,它的標頭檔形式如下:
如何使用spring的範圍:
<bean id="role" class="spring.chapter2.maryGame.Role" scope="singleton"/>
這裡的 scope 就是用來配置 spring bean 的範圍,它標識 bean 的範圍。
在spring2.0之前bean只有2種範圍即:singleton(單例)、non-singleton(也稱 prototype), Spring2.0以後,增加了session、request、global session三種專用於Web應用程式內容相關的Bean。因此,預設情況下Spring2.0現在有五種類型的Bean。當然,Spring2.0對 Bean的類型的設計進行了重構,並設計出靈活的Bean類型支援,理論上可以有無數多種類型的Bean,使用者可以根據自己的需要,增加新的Bean類 型,滿足實際應用需求。1、singleton 範圍當一個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 id="role" class="spring.chapter2.maryGame.Role" scope="singleton"/>或者<bean id="role" class="spring.chapter2.maryGame.Role" singleton="true"/>
2、prototype
prototype範圍部署的bean,每一次請求(將其注入到另一個bean中,或者以程式的方式調用容器的 getBean()方法)都會產生一個新的bean執行個體,相當與一個new的操作,對於prototype範圍的bean,有一點非常重要,那就是Spring不能對一個prototype bean的整個生命週期負責,容器在初始化、配置、裝飾或者是裝配完一個prototype執行個體後,將它交給用戶端,隨後就對該prototype執行個體不聞不問了。不管何種範圍,容器都會調用所有對象的初始化生命週期回調方法,而對prototype而言,任何配置好的析構生命週期回調方法都將不會被調用。 清除prototype範圍的對象並釋放任何prototype bean所持有的昂貴資源,都是用戶端代碼的職責。(讓Spring容器釋放被singleton範圍bean佔用資源的一種可行方式是,通過使用 bean的後置處理器,該處理器持有要被清除的bean的引用。)配置執行個體:
<bean id="role" class="spring.chapter2.maryGame.Role" scope="prototype"/>或者<beanid="role" class="spring.chapter2.maryGame.Role" singleton="false"/>
3、request
request表示該針對每一次HTTP請求都會產生一個新的bean,同時該bean僅在當前HTTP request內有效,配置執行個體:request、session、global session使用的時候首先要在初始化web的web.xml中做如下配置:如果你使用的是Servlet 2.4及以上的web容器,那麼你僅需要在web應用的XML聲明檔案web.xml中增加下述ContextListener即可:
<web-app> ... <listener><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的範圍了:
<bean id="role" class="spring.chapter2.maryGame.Role" scope="request"/>
4、session
session範圍表示該針對每一次HTTP請求都會產生一個新的bean,同時該bean僅在當前HTTP session內有效,配置執行個體:配置執行個體:和request配置執行個體的前提一樣,配置好web開機檔案就可以如下配置:
<bean id="role" class="spring.chapter2.maryGame.Role" scope="session"/>
5、global 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 id="role" class="spring.chapter2.maryGame.Role" scope="global session"/>
spring中scope範圍(轉)