注:示例来自《大话设计模式》
所有类都有构造方法 不编码则系统默认生成空的构造方法 若有显示定义的构造方法 默认的构造方法就会失效
单例模式 保证一个类仅有一个实例 并提供一个访问它的全局访问点
通常我们可以让一个全局变量使得一个对象被访问 但它不能防止你实例化多个对象 一个最好的办法就是 让类自身负责保存它的唯一实例 这个类可以保证没有其他实例可以被创建 并且它可以提供一个访问该实例的方法
Singleton类
package Test21;
public class Singleton {
private static Singleton instance;
private Singleton()
{
}
public static Singleton GetInstance()
{
if (instance == null)
{
instance = new Singleton();
}
return instance;
}
}
测试代码
package Test21;
public class Program {
public static void main(String[] args) {
Singleton s1 = Singleton.GetInstance();
Singleton s2 = Singleton.GetInstance();
if (s1 == s2)
{
System.out.println("两个对象是相同的实例");
}
}
}
单例模式因为Singleton类封装它的唯一实例 这样它可以严格地控制客户怎样访问它以及何时访问它 简单地说就是对唯一实例的受控访问
上面的写法线程不安全 下面使用双重锁定进行重构 代码如下
package Test21;
public class Singleton {
private static Singleton instance;
private Singleton()
{
}
public static Singleton GetInstance()
{
if (instance == null)
{
synchronized (Singleton.class)
{
if (instance == null)
{
instance = new Singleton();
}
}
}
return instance;
}
}
还有一种静态初始化的方法也可以解决线程不安全的问题 代码如下
package Test21;
public class Singleton {
private static final Singleton instance = new Singleton();
private Singleton() { }
public static Singleton GetInstance()
{
return instance;
}
}
这种静态初始化的方式是在自己被加载时就将自己实例化 所以被形象地称之为饿汉式单例类 最上面的处理方式是要在第一次被引用时 才会将自己实例化 所以就被称为懒汉式单例类