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


此文轉載

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

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

首先示眾一篇大錯特錯的文章,誰有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