Java設(shè)計模式之單例模式簡介
一、餓漢式(靜態(tài)常量)
public class Face {
private static final Face instance = new Face();
static Face getInstance() {
return instance;
}
private Face() {
}
}
- 優(yōu)點:這種寫法比較簡單,就是在類裝載的時候就完成實例化。避免了線程同步問題。
- 缺點:在類裝載的時候就完成實例化,沒有懶加載的效果。如果從始至終從未使用過這個實例,則會造成內(nèi)存的浪費。
二、餓漢式(靜態(tài)代碼塊)
public class Face {
private static Face instance;
static {
instance = new Face();
}
private Face() {
}
public static Face getInstance() {
return instance;
}
}
- 優(yōu)點:這種寫法比較簡單,就是在類裝載的時候就完成實例化。避免了線程同步問題。
- 缺點:在類裝載的時候就完成實例化,沒有達到懶加載的效果。如果從始至終從未使用過這個實例,則會造成內(nèi)存的浪費。
三、懶漢式(線程不安全)
public class Face {
private static Face instance;
private Face() {
}
public static Face getInstance() {
if (null == instance) {
instance = new Face();
}
return instance;
}
}
- 優(yōu)點:懶加載,只有使用的時候才會加載。
- 缺點:但是只能在單線程下使用。如果在多線程下,一個線程進入了if (null == instance)判斷語句塊,還未來得及往下執(zhí)行,另一個線程也通過了這個判斷語句,這時便會產(chǎn)生多個實例。所以在多線程環(huán)境下不可使用這種方式
四、懶漢式(線程安全,同步方法)
public class Face {
private static Face instance;
private Face() {
}
public static synchronized Face getInstance() {
if (null == instance) {
instance = new Face();
}
return instance;
}
}
- 優(yōu)點:懶加載,只有使用的時候才會加載,獲取單例方法加了同步鎖,保障線程安全。
- 缺點:效率太低了,每個線程在想獲得類的實例時候,執(zhí)行g(shù)etInstance()方法都要進行同步。
五、懶漢式(線程不安全,同步代碼塊)
public class Face {
private static Face instance;
private Face() {
}
public static Face getInstance() {
if (null == instance) {
synchronized (Face.class) {
instance = new Face();
}
}
return instance;
}
}
- 優(yōu)點:改進了 懶漢式(線程安全,同步方法) 效率低的問題。
- 缺點:不能完全保證單例,假如一個線程進入了if (null == instance)判斷語句塊,還未來得及往下執(zhí)行,另一個線程也通過了這個判斷語句,這時便會產(chǎn)生多個實例。
六、雙重檢查( DCL )
public class Face {
private static volatile Face instance;
private Face() {
}
public static Face getInstance() {
if (null == instance) {
synchronized (Face.class) {
if (null == instance) {
instance = new Face();
}
}
}
return instance;
}
}
- 優(yōu)點:線程安全;延遲加載;效率較高。
- 缺點:JDK < 1.5 的時候不可用
- 不可用原因:由于volatile關(guān)鍵字會屏蔽Java虛擬機所做的一些代碼優(yōu)化,可能會導致系統(tǒng)運行效率降低,而JDK 1.5 以及之后的版本都修復了這個問題。(謹記?。。。?/li>
七、靜態(tài)內(nèi)部類
public class Face {
private static volatile Face instance;
private Face() {
}
private static class FaceInstance {
private static final Face faceInstance = new Face();
}
public static Face getInstance() {
return FaceInstance.faceInstance;
}
}
- 優(yōu)點:避免了線程不安全,延遲加載,效率高。
- 缺點:暫無,最推薦使用。
- 特點:這種方式跟餓漢式方式采用的機制類似,但又有不同。
- 兩者都是采用了類裝載的機制來保證初始化實例時只有一個線程。不同的地方在餓漢式方式是只要Singleton類被裝載就會實例化,沒有懶加載的作用,而靜態(tài)內(nèi)部類方式在Singleton類被裝載時并不會立即實例化,而是在需要實例化時,調(diào)用getInstance方法,才會裝載SingletonInstance類,從而完成Singleton的實例化。類的靜態(tài)屬性只會在第一次加載類的時候初始化,所以在這里,JVM幫助我們保證了線程的安全性,在類進行初始化時,別的線程是無法進入的。
八、單例模式的優(yōu)點
可以減少系統(tǒng)內(nèi)存開支,減少系統(tǒng)性能開銷,避免對資源的多重占用、同時操作
到此這篇關(guān)于Java設(shè)計模式之單例模式簡介的文章就介紹到這了,更多相關(guān)Java單例模式簡介內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Maven中Could not find artifact XXXX的錯誤解決
本文主要介紹了Maven中Could not find artifact XXXX的錯誤解決,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
springboot內(nèi)置tomcat之NIO處理流程一覽
這篇文章主要介紹了springboot內(nèi)置tomcat之NIO處理流程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
SpringBoot實現(xiàn)application配置信息加密
在配置文件中,我們有開發(fā)環(huán)境配置和生產(chǎn)環(huán)境配置,而生產(chǎn)環(huán)境的配置信息是需要做好防護的,避免外泄,所以本文為大家整理了application配置信息加密的方法,需要的可以參考下2023-07-07
SpringBoot3.x版本與Mybatis-Plus不兼容問題
當使用3.x版本的SpringBoot結(jié)合Mybatis-Plus時版本不兼容就會報錯,本文就來介紹一下這個問題的解決方法,感興趣的可以了解一下2024-03-03
springboot讀取bootstrap配置及knife4j版本兼容性問題及解決
這篇文章主要介紹了springboot讀取bootstrap配置及knife4j版本兼容性問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06
使用synchronized關(guān)鍵字實現(xiàn)信號量的方法
在Java中,信號量(Semaphore)是一種常用的同步工具,它可以用來控制對共享資源的訪問數(shù)量,下面,我們將使用Synchronized關(guān)鍵字來實現(xiàn)一個簡單的信號量,我們的目標是實現(xiàn)一個計數(shù)信號量,其中信號量的計數(shù)指示可以同時訪問某一資源的線程數(shù),需要的朋友可以參考下2024-04-04

