更新時間:2023-09-12 來源:黑馬程序員 瀏覽量:
IT就到黑馬程序員.gif)
要編寫一個線程安全的單例模式(Singleton)類,我們可以使用以下方法之一。這兩種方法都確保只有一個實例被創(chuàng)建,并且在多線程環(huán)境中安全使用。
  在懶漢式中,實例在第一次被請求時才會被創(chuàng)建。
public class Singleton {
    private static Singleton instance;
    private Singleton() {
        // 私有構(gòu)造函數(shù),防止外部實例化
    }
    public static synchronized Singleton getInstance() {
        if (instance == null) {
            instance = new Singleton();
        }
        return instance;
    }
}  這種方法使用了synchronized關(guān)鍵字來確保線程安全,但它會引入性能開銷,因為每次調(diào)用getInstance方法都會進行同步。
  雙重檢查鎖定允許我們在沒有同步的情況下創(chuàng)建實例,只有在實例不存在時才進行同步。
public class Singleton {
    private static volatile Singleton instance;
    private Singleton() {
        // 私有構(gòu)造函數(shù),防止外部實例化
    }
    public static Singleton getInstance() {
        if (instance == null) {
            synchronized (Singleton.class) {
                if (instance == null) {
                    instance = new Singleton();
                }
            }
        }
        return instance;
    }
}在這個版本中,我們使用了volatile關(guān)鍵字來確保instance變量對所有線程可見,避免了可能的重排序問題。
使用上述任何一種方法都可以創(chuàng)建一個線程安全的單例模式類。如果我們使用Java 5或更高版本,強烈建議使用雙重檢查鎖定方法,因為它在性能上有一些優(yōu)勢。但要注意,這些示例中的單例模式是懶加載的,只有在需要時才會創(chuàng)建實例。如果我們需要在應(yīng)用程序啟動時立即創(chuàng)建實例,可以使用餓漢式(Eager Initialization)方法。