Java单例模式的各种写法和最优写法推荐

话不多说,直接上代码:

(1)

//只适合单线程环境,懒汉模式
 class Singleton{

    private static Singleton Instance = null;
    
     public Singleton() {
     }
     
     public static Singleton getInstance(){
       if(Instance==null){
           Instance = new Singleton();
       }
        return Instance;
    }
 }
评价:由于只生成一个实例,为防止别人创建该类实例,构造方法为私有属性,只有在实例对象为空时才去创建(为避免重复创建)。

 
  
//饿汉模式
 class Singleton{

    private static Singleton Instance = new Singleton();
    
     public Singleton() {
     }
     
     public static Singleton getInstance(){
        return Instance;
    }
 }
评价:开始的时候就创建一个final类型的静态实例对象,以后不会再改变。

//双重判断
 
  
class Singleton{

   private static Singleton Instance = null;

    public Singleton() {
    }

    public static Singleton getInstance(){
      if(Instance==null){
          synchronized (Singleton.class) {
              if (Instance == null) {
                  Instance = new Singleton();
              }
          }
      }
       return Instance;
   }
}
评价:经过两次判定,第一次检测到实例为空时,增加同步,同步后再次检测到实例为空时,才创建对象实例。有效防止了在多线程环境下创建多个实例的问题。

(4)
//volatile 关键字的使用
private static volatile Singleton singleton;
 
  

volatile 关键字的使用可以解决一定程度上的多线程访问时出现的同步问题,保证一定程度的线程安全。如果整形的变量由volatile修饰,在其值发生改变后,

能够快速被其他线程可见,告知其他线程自己发生改变。

(5)结合volatile的单例模式
 
  
 class Singleton{
     private static volatile Singleton Instance=null;
     public Singleton() {
     }

     public static Singleton getInstance(){
       if(Instance==null){
           synchronized (Singleton.class) {
               if (Instance == null) {
                   Instance = new Singleton();
               }
           }
       }
        return Instance;
    }
 }
评价:在volatile 和synchronized 两端线程安全的保护下,保证了多线程访问情况下出现多个实例的问题。volatile 保证在实例对象创建后快速通知其他线程
该对象的实例已经存在,不需要重复创建了。主要突出了可见性。



你可能感兴趣的:(Java单例模式的各种写法和最优写法推荐)