单例模式:
单例模式有以下特点:
1、单例类只能有一个实例。
2、单例类构造器私有。
懒汉式单例:
public class Singleton() {
private Singleton() {
}
private static Singleton m_instance = NULL;
public static Singleton getInstance() {
return this.m_instance == NULL ? new Singleton() : m_instance;
}
}
Singleton通过将构造方法私有化避免了类在外部被实例化,等到需要实例的时候再在内部实例化。
这种方法是线程不安全的,在并发环境下可能回出现多个实例,有如下解决方法。
在getInstance()方法上加上同步,这种方法性能较差,因为每次都需要同步,除了第一次调用时之外,都是不需要同步的。
public class Singleton() {
private Singleton() {
}
private static Singleton m_instance = NULL;
public static synchronized Singleton getInstance() {
return this.m_instance == NULL ? new Singleton() : m_instance;
}
}
双重检查,这种方法通过判断实例是否已创建避免每次都要同步导致影响性能。
public class Singleton() {
private Singleton() {
}
private static final Singleton m_instance = NULL;
public static Singleton getInstance() {
if(m_instance == NULL){
synchronized(Singleton.class) {
return m_instance == NULL ? new Singleton() : m_instance;
}
}
return m_instance;
}
}
静态内部类,利用了classloader的机制来保证初始化instance时只有一个线程,所以是线程安全的,同时没有性能损耗。
public class Singleton() {
private Singleton() {
}
private static class LazyHolder() {
private static final Singleton m_instance = new Singleton();
}
public static synchronized Singleton getInstance() {
return this.LazyHolder.m_instance;
}
}
饿汉式单例,线程安全:
public class Singleton() {
private Singleton() {
}
private static final Singleton m_instance = new Singleton();
public static Singleton getInstance() {
return this.m_instance;
}
}