Spring?bean配置單例或多例模式方式
Spring bean配置單例或多例模式
單例
spring bean 默認是單例默認,在對應.xml文件中的配置是:
<bean id="user" class="..." scope="singleton"/>
singleton就是配置這個bean是否是單例的,如果不寫,就是默認值true。
單例模式:每個bean定義只生成一個對象實例,每次getBean請求獲得的都是此實例
單例模式分為餓漢模式和懶漢模式,
餓漢模式 | spring singleton的缺省是餓漢模式:啟動容器時(即實例化容器時),為所有spring配置文件中定義的bean都生成一個實例 |
懶漢模式 | 在第一個請求時才生成一個實例,以后的請求都調用這個實例spring singleton設置為懶漢模式:<beansdefault-lazy-init="true"> |
多例
配置多例:
<bean id="user" class="..." scope="prototype"/>
多例模式:任何一個實例都是新的實例,調用getBean時,就new一個新實例
Spring scope配置單例、多例模式
1、scope屬性介紹
scope="“是標簽的一個屬性,作用是:控制對象的作用范圍(單例、多例模式)
取值:scope=”"是標簽的一個屬性,作用是:控制對象的作用范圍(單例、多例模式)
當時導入包spring-mvc和包spring-mvc-portlet可以使用下列值(web應用):
request
:當每次請求時實例化。session
:當在一個session周期內,對象時單例的。globalSession
:依賴包spring-mvc-portlet,類似于session.application
:在一個application對象內是單例的。singleton
:默認值,單例模式;prototype
:多例,每次獲取對象都會重新實例化;
所需包:
2、scope配置
Application.xml:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation=" http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd"> <bean id="user" class="Model.User" scope="singleton"> <aop:scoped-proxy/> </bean> </beans>
3、單例模式底層實現(xiàn)模擬
3.1、 模擬單例模式 — 懶漢式
**懶漢式的優(yōu)點是:**
1、提升運行效率;
2、實現(xiàn)數據共享,例如application對象,application對象單例模式,在程序啟動,對象實例化之后,程序結束之前,實例化的對象都可以實現(xiàn)共享。
懶漢式的缺點是:使用了多線程鎖機制,導致效率低。
實現(xiàn):
package SingleTon; public class SingleTon { private static SingleTon singleTon; /** * 創(chuàng)建對象一般都是用new XX(),此處XX()是類對象的無參構造方法 * 一般無參構造方法都public XX(){},但是單例模式使用private修飾構造方法, * 這樣是為了不讓其它類創(chuàng)建單例對象。 * * 構造方法的兩個條件:方法名與類名相同,沒有返回值 */ private SingleTon(){ } /** * 實例方法,使用實例方法創(chuàng)建對象, * 因為實例方法需要對象才能調用,然而構造方法時private修飾的,其他類不能使用, * 因此實例方法應該是靜態(tài)的(static),使用public修飾,其他類可以使用,返回值要是類對象. * */ public static SingleTon getInstance(){ /** * 判斷對象是否已經被創(chuàng)建,要有一個全局的類類型的參數 * 靜態(tài)方法不能使用非靜態(tài)的變量,因此變量應該設置成靜態(tài)的(static) */ if(singleTon == null){ /** * 如果是多線程的,此處需要使用鎖,所對象使用該類對象 * 例如:同時兩個線程使用該對象,該對象還為實例化,此處如果不使用鎖就會導致對象被重復實例化,不符合單例模式 */ synchronized(SingleTon.class){ /** * 雙重驗證,防止多線程重復實例化對象 * * 使用鎖缺點:效率較低。 */ if(singleTon == null){ new SingleTon(); } } } return singleTon; } }
3.2、餓漢式:優(yōu)點是解決了懶漢式效率低的缺點。
package SingleTon; /*** * 單例模式 -- 餓漢式 */ public class SingleTon2 { /** * 餓漢式構造方法、全局變量、實例方法都與懶漢式一樣,區(qū)別在于餓漢式在全局變量處就已經實例化了對象 * 餓漢式不用考慮多線程問題,解決了懶漢式效率低的問題。 */ private static SingleTon2 singleTon2 = new SingleTon2(); /** * 構造方法 */ private SingleTon2(){} /** * 實例方法 */ public static SingleTon2 getInstance(){ return singleTon2; } }
3.3、測試方法:
package SingleTon; public class Test { public static void main(String[] args) { SingleTon singleTon = SingleTon.getInstance(); System.out.println(singleTon); } }
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
java中gradle項目報錯org.gradle?.api.plugins.MavenPlugin解決辦法
在使用Gradle時開發(fā)者可能會遇到org.gradle?.api.plugins.MavenPlugin報錯提醒,這篇文章主要給大家介紹了關于java中gradle項目報錯org.gradle?.api.plugins.MavenPlugin的解決辦法,需要的朋友可以參考下2023-12-12SpringBoot定制化Starter實現(xiàn)方法
小伙伴們曾經可能都經歷過整天寫著CURD的業(yè)務,都沒寫過一些組件相關的東西,這篇文章記錄一下SpringBoot如何自定義一個Starter。原理和理論就不用多說了,可以在網上找到很多關于該方面的資料,這里主要分享如何自定義2023-01-01