更新時間:2023-09-12 來源:黑馬程序員 瀏覽量:
要編寫一個線程安全的單例模式(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)方法。