java單例模式幾種實現方式


單例模式的五種實現方式

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

 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     }
View Code

 

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 }
View Code

 

5.枚舉類(線程安全,調用效率高,不能延時加載,可以天然的防止反射和反序列化調用)

1 public enum SingletonDemo4 {
2      
3     //枚舉元素本身就是單例
4     INSTANCE;
5      
6     //添加自己需要的操作
7     public void singletonOperation(){     
8     }
9 }
View Code

 

 

如何選用:

-單例對象 占用資源少,不需要延時加載,枚舉 好於 餓漢

-單例對象 占用資源多,需要延時加載,靜態內部類 好於 懶漢式

  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM