1. 程式人生 > 實用技巧 >基於Docker的Redis叢集環境搭建【Centos7、Docker、Redis5.0.7】

基於Docker的Redis叢集環境搭建【Centos7、Docker、Redis5.0.7】

單例模式的五種實現方式

1、餓漢式(執行緒安全,呼叫效率高,但是不能延時載入):

1 2 3 4 5 6 7 publicclassImageLoader{ privatestaticImageLoader instance =newImageLoader; privateImageLoader(){} publicstaticImageLoader getInstance(){ returninstance; } }

一上來就把單例物件創建出來了,要用的時候直接返回即可,這種可以說是單例模式中最簡單的一種實現方式。但是問題也比較明顯。單例在還沒有使用到的時候,初始化就已經完成了。也就是說,如果程式從頭到位都沒用使用這個單例的話,單例的物件還是會建立。這就造成了不必要的資源浪費。所以不推薦這種實現方式。

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底層模型原因,偶爾會出問題,不建議使用):

 1 public class SingletonDemo5 {
 2         private volatile static SingletonDemo5 SingletonDemo5;
 3  
 4         private SingletonDemo5() {
 5         }
 6  
 7         public static SingletonDemo5 newInstance() {
 8             if (SingletonDemo5 == null) {
 9                 synchronized (SingletonDemo5.class) {
10                     if (SingletonDemo5 == null) {
11                         SingletonDemo5 = new SingletonDemo5();
12                     }
13                 }
14             }
15             return SingletonDemo5;
16         }
17     }

4.靜態內部類實現模式(執行緒安全,呼叫效率高,可以延時載入)

 1 public class SingletonDemo3 {
 2      
 3     private static class SingletonClassInstance{
 4         private static final SingletonDemo3 instance=new SingletonDemo3();
 5     }
 6      
 7     private SingletonDemo3(){}
 8      
 9     public static SingletonDemo3 getInstance(){
10         return SingletonClassInstance.instance;
11     }
12      
13 }

5.列舉類(執行緒安全,呼叫效率高,不能延時載入,可以天然的防止反射和反序列化呼叫)

View Code

如何選用:

-單例物件 佔用資源少,不需要延時載入,列舉 好於 餓漢

-單例物件 佔用資源多,需要延時載入,靜態內部類 好於 懶漢式