设计模式之Singleton(单例模式)

本文介绍了Singleton设计模式的两种实现形式:一种是在类加载时初始化实例,另一种则是延迟初始化(Lazy Initialization)。详细解释了这两种形式的区别及优缺点,并指出同步机制对于避免多线程环境下产生多个实例的重要性。

一般Singleton模式通常有几种形式

public class Singleton

{

  private Singleton(){}

 

  //在自己内部定义自己一个实例,是不是很奇怪?
  //注意这是private 只供内部调用

 

  private static Singleton instance = new Singleton();

 

  //这里提供了一个供外部访问本class的静态方法,可以直接访问

  
  public static Singleton getInstance() {
    return instance;   
   }
}

 

第二种形式:

 

public class Singleton {

  private static Singleton instance = null;

  public static synchronized Singleton getInstance() {

  if (instance==null)
    instance=new Singleton();
  return instance;   }

}

 

 

使用Singleton.getInstance()可以访问单态类。

上面第二中形式是lazy initialization,也就是说第一次调用时初始Singleton,以后就不用再生成了。

注意到lazy initialization形式中的synchronized,这个synchronized很重要,如果没有synchronized,那么使用getInstance()是有可能得到多个Singleton实例。关于lazy initialization的Singleton有很多涉及double-checked locking (DCL)的讨论,有兴趣者进一步研究。

一般认为第一种形式要更加安全些。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值