1. 程式人生 > 其它 >單例模式的五種實現方式

單例模式的五種實現方式

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

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