建立型模式之單例模式,建立型
定義1、定義:
確保一個類只有一個執行個體,而且自行執行個體化並向整個系統提供這個執行個體。
使用單例模式的時機是當執行個體存在多個會引起程式邏輯錯誤的時候。比如類似有序的號碼產生器這樣的東西,怎麼可以允許一個應用上存在多個呢?Singleton模式主要作用是保證在Java應用程式中,一個類Class只有一個執行個體存在。
常見應用情境:
2、類圖
1.類圖分為三部分,依次是類名、屬性、方法
2.以<<開頭和以>>結尾的為注釋資訊
3.修飾符+代表public,-代表private,#代表protected,什麼都沒有代表包可見。
4.帶底線的屬性或方法代表是靜態。
單例模式,它有以下幾個要素:
- 私人的構造方法
- 指向自己執行個體的私人靜態引用
- 以自己執行個體為傳回值的靜態公有的方法
3、分類
常見的四種單例模式的實現方式:
-餓漢式(安全執行緒,調用效率高,不能延時載入)
-懶漢式(安全執行緒,調用效率不高,可延時載入)
-靜態內部類式(安全執行緒,調用效率高,可延時載入)
-枚舉單例(安全執行緒,調用效率高,不能延時載入,並且可以避免通過反射和序列化建立新對象)
餓漢式
所謂“懶漢式”與“餓漢式”的區別,是在於建立單例對象的時間不同。“懶漢式”是在你真正用到的時候才去建這個單例對象:
/餓漢式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(); } }}