確保一個類只有一個實例,而且自行實例化並向整個系統提供這個實例。
使用單例模式的時機是當實例存在多個會引起程序邏輯錯誤的時候。比如類似有序的號碼生成器這樣的東西,怎麼可以允許一個應用上存在多個呢?Singleton模式主要作用是保證在Java應用程序中,一個類Class只有一個實例存在。
常見應用場景:
1.類圖分為三部分,依次是類名、屬性、方法
2.以<<開頭和以>>結尾的為注釋信息
3.修飾符+代表public,-代表private,#代表protected,什麼都沒有代表包可見。
4.帶下劃線的屬性或方法代表是靜態的。
單例模式,它有以下幾個要素:
常見的四種單例模式的實現方式:
-餓漢式(線程安全,調用效率高,不能延時加載)
-懶漢式(線程安全,調用效率不高,可延時加載)
-靜態內部類式(線程安全,調用效率高,可延時加載)
-枚舉單例(線程安全,調用效率高,不能延時加載,並且可以避免通過反射和序列化創建新對象)
所謂“懶漢式”與“餓漢式”的區別,是在於建立單例對象的時間不同。“懶漢式”是在你真正用到的時候才去建這個單例對象:
/餓漢式 public class SingletonTest01 { //類初始化裝載的時候,初始化該對象(類初始化是天然的線程安全) private static SingletonTest01 instance = new SingletonTest01(); // 私有的構造器 private SingletonTest01() { } // 方法沒有同步塊,並發效率高 public static SingletonTest01 getInstance() { return instance; } }
/單例模式:懶漢式 public class SingletonTest02 { //類初始化裝載的時候,不初始化該對象(延時加載,真正使用的時候再創建) private static SingletonTest02 instance;
private SingletonTest02() { } //方法需同步保證線程安全,調用效率低 public static synchronized SingletonTest02 getInstance() { if (instance != null) { return instance; } else { return new SingletonTest02(); } } }