介绍
单例模式是一种创建型模式。它保证一个类仅有一个实例,并提供一个访问它的全局访问点。
实现方式
1.饿汉式(线程安全、没有懒加载)
publc class Singleton{
private static Singleton mInstance = new Singleton();
pirvate Singleton(){}
public static Singleton getInstance(){
return mInstance;
}
}
特点:直接在应用加载时初始化,但会浪费内存。
解析:在类初始化时已经初始化实例,线程安全的。
2.双重校验锁(线程安全,有懒加载)
public class Singleton(){
private static volatile Singleton mInstance;
private Singleton(){}
public static Singleton getInstance(){
if(mInstance == null){
synchronized(Singleton.class){
if(mInstance == null){
mInstance = new Singleton();
}
}
}
return mInstance;
}
}
特点:线程安全,避免了不必要的同步,但高并发环境下小概率会有DCL失效问题。
解析:instance = new Singleton();语句,大概做了3件事情:
(1)、给Singleton的实例分配内存
(2)、调用Singleton()的构造函数
(3)、将instance对象指向分配的内存空间(instance不是null了)
3.静态内部类的单例模式(线程安全,有懒加载)
public class Singleton(){
private Singleton(){}
public static Singleton getInstance(){
return SingletonHolder.mInstance;
}
private static class SingletonHolder(){
public static SingletonHolder mInstance = new Singleton();
}
}
特点:懒加载的同时保证线程安全,推荐使用
解析:为什么会线程安全?类的构造器()方法在多线程环境中被正确地加载,同步,如果多个线程同时去初始化一个类,那么只有一个线程去执行这个类的,其他线程都需要阻塞等待,直到活动线程执行()方法完毕。