單例模式三種模式,餓漢(飢漢)、飽漢(懶漢)、雙重鎖模式


今天看某培訓機構提供面試題中設計模式部分,對飽漢和餓漢比較感興趣,就搜了一下,然后誤人子弟,然后就覺得有必要記錄一下

聲明:本人沒有看過設計模式的書籍,只是根據概念對比的看了一些博客;

首先示眾一篇大錯特錯的文章,誰有CSDN帳號,提醒他把文章刪了吧,錯的離譜
https://blog.csdn.net/j_a_v_a_guan/article/details/48004007

 

經典寫法:
懶漢和餓漢的最大區別就在於創建對象時候是否實例化;有new就是餓漢,反之就是懶漢,跟加不加
synchronized ,沒有關系
懶漢:

public class SingleTon {

private static SingleTon instance;

private SingleTon() {

}

public static SingleTon getInstance() {
if (instance == null) {
instance = new SingleTon();
}
return instance;
}}

懶漢安全寫法

public class SingleTon {

// 靜態實例變量加上volatile
private static volatile SingleTon instance;

// 私有化構造函數
private SingleTon() {

}

// 雙重檢查鎖
public static SingleTon getInstance() {
if (instance == null) {
synchronized(Singleton.class){
if(instance == null){
instance = new SingleTon();
}
}
}
return instance;
}

}

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

餓漢模式 public class SingleTon { // 靜態實例變量,直接初始化
    private static SingleTon instance = new SingleTon(); // 私有化構造函數
    private SingleTon() { } // 靜態public方法,向整個應用提供單例獲取方式
    public static SingleTon getInstance() { return instance; } }

================================================================================================================================================

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM