探讨单例模式与多线程单例模式

 Singleton模式主要作用是保证在Java应用程序中,一个类Class只有一个实例存在。

好处:

     和全局变量相比,它对于系统性能的优化更好,因为它是属于什么时候用,什么时候实例化的。

  一般Singleton模式通常有两种形式:

  第一种形式: 也是常用的形式。

  public class Singleton {   private static Singleton instance = null;   private Singleton(){   //do something   }   //这个方法比下面的有所改进,不用每次都进行生成对象,只是第一次使用时生成实例,提高了效率   public static Singleton getInstance(){   if(instance==null){   instance = new Singleton();   }   return instance;   }   }

 

  第二种形式:

  public class Singleton {   //在自己内部定义自己的一个实例,只供内部调用   private static Singleton instance = new Singleton();   private Singleton(){   //do something   }   //这里提供了一个供外部访问本class的静态方法,可以直接访问   public static Singleton getInstance(){   return instance;   }   } 

ps:在静态初始化器中创建单件,这段代码就保证了线程安全。

 

对于多线程的访问,我们多半采用第二种“急切”的方式,而不用第一种延迟处理的方式,这样就会解决多线程对单一访问点访问造成顺序执行出错的问题。

 

还有一种方式:用双重检查枷锁,在getInstance()中减少使用同步

public class Singleton{ private volatile static Singleton instance; private Singleton(){} public static Singleton getInstance(){ if(instance==null){ synchronized(Singletion.class){ if(instance == null){ instance = new Singleton(); } } } return instance; } } 

volatile关键词确保:当instance变量被初始化成Singletion实例时,多个线程正确地处理instance变量,因为它会强制变量去对应内存中共享的变量

转载于:https://www.cnblogs.com/yangchao/archive/2011/06/22/2125190.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值