1.单例模式
保证一个类在系统中只有一个对象被实例化。
如:缓存池,线程池,一些应用服务实例等;
难点:在多线程环境下,难以保证实例的唯一性;
2.最简单的单例模式
保证该类的构造方法是私有方法,外部无法创建该类的实例化对象;
提供一个全局访问点,方便给客户对象提供对此单例对象的使用;
public class Singleton{
/**
*私有变量,外界无法访问,可以定义 public类型instance变量,把属性直接暴露给客户对象,则没有必要实现get方法;
*但是可读性降低,而且直接暴露给客户对象实例变量名称给客户程序,耦合性增加;
*‘/
private static Singleton instance = new Singleton();
static{
}
private Singleton(){
}
private static Singleton getInstance(){
return instance;
}
}
//客户使用单例模式代码
Singleton singleton = new Singleton();
singleton.getInstance();
如果该实例对象需要实现复杂的初始化过程,可以放入静态块中;
注意:此实现是线程安全的,当多个线程同时访问该类的getInstance方法时候,不会初始化多个对象,原因是,jvm加载此类时候,对应static属性的初始化只能由一个线程执行,且仅此一次。
3.进阶
static类在加载时就会被初始化,出于性能等方面的考虑,我们希望延迟实例化对象,只有在第一次使用到该类的时候才去实例化;
4.延迟创建
public static Singleton getInstance(){
if(instance==null){
instance = new Singleton();
}
return instance;
}
我们把类的实例化过程移动到了getInstance方法。而不是在类加载时预先创建,当访问该类时候,首先判断该类是不是已经被实例化过来,如果已经实例化直接返回这个对象的引用。如果没有,则创建该类并返回该类的引用;
注意:方法是线程不安全的。
6.如何创建并发访问效率高的单例:double-checkLocking
public static Singleton getInstance(){
if(instance==null){
synchronized(Singleton.class){
if(instance==null){
instance = new Singleton;
}
}
}
return instance;
}