一文搞懂Spring中的Bean作用域
概述
scope用來聲明容器中的對象所應該處的限定場景或者說該對象的存活時間,即容器在對象進入其 相應的scope之前,生成并裝配這些對象,在該對象不再處于這些scope的限定之后,容器通常會銷毀這些對象。
Spring容器bean的作用域類型:
- singleton:Spring IoC 容器的單個對象實例作用域都默認為singleton
- prototype:針對聲明為擁有prototype scope的bean定義,容器在接到該類型對象的請求的時候,會每次都重新生成一個新的對象實例給請求方
- request:將單個 bean 定義限定為單個 HTTP 請求的生命周期。也就是說,每個 HTTP 請求都有自己的 bean 實例,該實例是在單個 bean 定義的后面創(chuàng)建的。僅在 Web 感知 Spring ApplicationContext 的上下文中有效
- session:將單個 bean 定義限定為 HTTP 會話的生命周期。僅在 Web 感知 Spring ApplicationContext 的上下文中有效
- application:將單個 bean 定義限定為 ServletContext 的生命周期。僅在 Web 感知 Spring ApplicationContext 的上下文中有效
- websocket:將單個 bean 定義限定為 WebSocket 的生命周期。僅在 Web 感知 Spring ApplicationContext 的上下文中有效。
Singleton
配置中的bean定義可以看作是一個模板,容器會根據這個模板來構造對象。但是要根據這個模板
構造多少對象實例,又該讓這些構造完的對象實例存活多久,則由容器根據bean定義的scope語意來決 定。標記為擁有singleton scope的對象定義,在Spring的IoC容器中只存在一個實例,所有對該對象的引 用將共享這個實例。該實例從容器啟動,并因為第一次被請求而初始化之后,將一直存活到容器退出, 也就是說,它與IoC容器“幾乎”擁有相同的“壽命”。
singleton的bean具有的特性:1、在容器中只存在一個共享的實例對象,所有對該類型的bean的依賴都引用這一單一的實例 2、從容器啟動到它第一次請求被實例化開始,只要容器不被銷毀或者退出,該類型bean的單一實例就會一直存活。
? singleton類型bean工作原理
prototype
容器在接到該類型對象的請求的時候,會每次都重新 生成一個新的對象實例給請求方。所以,對于那些請求方不能共享使用的對象類型,應該將其bean定義的scope設置為prototype。這樣,每個請求方可以得到自己對應的一個對象實例。
與其他作用域相比,Spring并不管理Prototype類型Bean的整個生命周期,因此在原型的情況下,配置的銷毀生命周期回調不會被調用,客戶端代碼必須清理原型范圍內的對象,并釋放原型Bean所持有的昂貴資源。
request
Spring容器會為每個HTTP請求創(chuàng)建一個全新的Request-Processor對象供當前請求使用,當請求結束后,該對象實例的生命周期即告結束。當同時有10個HTTP 請求進來的時候,容器會分別針對這10個請求返回10個全新的RequestProcessor對象實例,且它們 之間互不干擾。從不是很嚴格的意義上說,request可以看作prototype的一種特例,除了場景更加具體 之外,語意上差不多。
session
Spring容器會為每個獨立的session創(chuàng)建屬于它們自己的全新的UserPreferences對象實例,除了擁有session scope的bean的實例具有比request scope的bean可能更長的存活時間,其他并無太大差異。
application
Spring容器通過為整個Web應用程序使用一次appPreferences Bean定義來創(chuàng)建AppPreferences Bean的新實例。這有點類似于 Spring 單例 bean,但在兩個重要方面有所不同:它是每個 ServletContext 的單例,而不是每個 Spring ApplicationContext
到此這篇關于一文搞懂Spring中的Bean作用域的文章就介紹到這了,更多相關Spring Bean作用域內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java基于二維數(shù)組實現(xiàn)的數(shù)獨問題示例
這篇文章主要介紹了Java基于二維數(shù)組實現(xiàn)的數(shù)獨問題,涉及java針對數(shù)組的遍歷、計算、轉換等相關操作技巧,需要的朋友可以參考下2018-01-01MyBatis-Plus通用枚舉自動關聯(lián)注入的實現(xiàn)
本文主要介紹了MyBatis-Plus通用枚舉自動關聯(lián)注入的實現(xiàn),解決了繁瑣的配置,讓 mybatis 優(yōu)雅的使用枚舉屬性,感興趣的可以一起來了解一下2021-06-06SpringBoot用@Async注解實現(xiàn)異步任務
這篇文章主要介紹了SpringBoot用@Async注解實現(xiàn)異步任務,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-12-12Quarkus中ConfigSourceInterceptor的加密配置實現(xiàn)
這篇文章主要為大家介紹Quarkus中ConfigSourceInterceptor加密配置的實現(xiàn)方式,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-02-02Java導出多個excel表打包到zip文件中供客戶端另存為窗口下載實現(xiàn)方法
最近的項目有一個導出匯總數(shù)據的要求,考慮到用戶軟件的差異,所以要分別導出xls以及xlsx并且打包提供下載,下面這篇文章主要給大家介紹了關于Java導出多個excel表打包到zip文件中供客戶端另存為窗口下載的實現(xiàn)方法,需要的朋友可以參考下2023-12-12基于Mybatis實現(xiàn)CRUD操作過程解析(xml方式)
這篇文章主要介紹了基于Mybatis實現(xiàn)CRUD操作過程解析(xml方式),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-11-11