# 单例模式
單例模式
方式七種
其中
餓漢 –> 餓漢變種--> 靜態內部類
懶漢 線程不安全 --> 懶漢 線程安全–> 雙重校驗鎖
枚舉法 網上最推薦的。stackoverflow 上點贊最多的….因為雙重校驗鎖有反射存在的問題
關鍵單詞
instance
enum
synchronized
應該先從餓漢模式開始看, 線程安全。
餓漢 ,
// #餓漢 public class Singleton{private static Singleton instance=new Singleton();private Singleton(){}public static Singleton getInstance(){return instance;} }這兩種沒什么區別,只不過放在了 靜態塊
//# 餓漢變種 public class Singleton{private Singleton instance=null;static{instance=new Singleton();}private Singleton(){}public static Singleton getInstance(){return this.instance;} }內部靜態類
//【推薦】5 靜態內部類,前兩種是只要singleton 被裝載,那么instance就被實例化 // 而這種方法使用調用getInstance 才會被裝載,從而實例化instance。 //目的,實例化instance 消耗資源大,希望延遲加載 public class Singleton{private static class SingletonHolder{private static final Singleton INSTANCE=new Singleton();}private Singleton(){}public static final Singleton getInstance(){return SingletonHolder.INSTANCE;} }餓漢式
// #懶漢 線程不安全 public class Singleton{private static Singleton instance;private Singleton(){}public static Singleton getInstance{if(instance == null){instance=new Singleton();}return instance;} } // #懶漢 線程 安全 效率低public class Singleton{private static Singleton instance;private Singleton(){}public static synchronized Singleton getInstance{if(instance==null){instance=new Singleton();}return instance;} } //【推薦】 雙重校驗鎖 public class Singleton{private static Singleton instance=null;private Singleton(){}public static final Singleton getInstance(){if(instance==null){synchronized(Singleton.class){if(Singleton==null)instance=new Singleton();}}} }//雙重校驗鎖仍然是有缺點的,極力推薦 enum法 //https://www.jianshu.com/p/1f856daa39c7枚舉
//【推薦】6 、 大神 枚舉法 !!! 可以避免 多線程同步問題,還能防止反序列化重新創建對象 public enum Singleton{INSTANCE;public void whaterverMethod(){} } //因為JVM會保證enum不能被反射并且構造器方法只執行一次。 //https://837062099.iteye.com/blog/1454934 //枚舉的本質 是枚舉 對象! ,http://c.biancheng.net/view/1100.html//https://www.cnblogs.com/alter888/p/9163612.html //枚舉實現原理 , 會生成相關的類,集成轉載于:https://www.cnblogs.com/EsMussSeinHui/p/11201352.html
總結
- 上一篇: Linux SWAP 交换分区
- 下一篇: 线段树 区间加 gcd 差分