單例模式的五種實現方式
阿新 • • 發佈:2021-07-09
1、餓漢式(執行緒安全,呼叫效率高,但是不能延時載入):
public
class
ImageLoader{
private
static
ImageLoader instance =
new
ImageLoader;
private
ImageLoader(){}
public
static
ImageLoader getInstance(){
return
instance;
}
}
一上來就把單例物件創建出來了,要用的時候直接返回即可,這種可以說是單例模式中最簡單的一種實現方式。但是問題也比較明顯。單例在還沒有使用到的時候,初始化就已經完成了。也就是說,如果程式從頭到位都沒用使用這個單例的話,單例的物件還是會建立。這就造成了不必要的資源浪費。所以不推薦這種實現方式。
2.懶漢式(執行緒安全,呼叫效率不高,但是能延時載入):
public class SingletonDemo2 { //類初始化時,不初始化這個物件(延時載入,真正用的時候再建立) private static SingletonDemo2 instance; //構造器私有化 private SingletonDemo2(){} //方法同步,呼叫效率低 public static synchronized SingletonDemo2 getInstance(){ if(instance==null){ instance=new SingletonDemo2(); } return instance; } }
3.Double CheckLock實現單例:DCL也就是雙重鎖判斷機制(由於JVM底層模型原因,偶爾會出問題,不建議使用):
public class SingletonDemo5 { private volatile static SingletonDemo5 SingletonDemo5; private SingletonDemo5() { } public static SingletonDemo5 newInstance() { if (SingletonDemo5 == null) { synchronized (SingletonDemo5.class) { if (SingletonDemo5 == null) { SingletonDemo5 = new SingletonDemo5(); } } } return SingletonDemo5; } }
4.靜態內部類實現模式(執行緒安全,呼叫效率高,可以延時載入)
public class SingletonDemo3 { private static class SingletonClassInstance{ private static final SingletonDemo3 instance=new SingletonDemo3(); }
private SingletonDemo3(){}
public static SingletonDemo3 getInstance(){ return SingletonClassInstance.instance; } }
5.列舉類(執行緒安全,呼叫效率高,不能延時載入,可以天然的防止反射和反序列化呼叫)
public enum SingletonDemo4 { //列舉元素本身就是單例 INSTANCE; //新增自己需要的操作 public void singletonOperation(){ } }