单列模式
单列模式简单来说就是只有一个实例,并且自己负责创建自己的对象。
双重锁模式线程安全的两个方面:执行控制(synchronized)和内存可见(volatile)。
/*单列模式*/
public class Singleton {
/* —————————— —————————— 懒汉模式(线程不安全) —————————— —————————— */
/* *//*指向自己实例的私有静态引用*//*
private static Singleton instance;
*//*造函数为 private,这样该类就不会被实例化*//*
private Singleton(){}
*//*以实例为返回值的静态的公有方法,静态工厂方法*//*
public static Singleton getSingleton(){
*//*被动创建,在真正需要使用时才去创建*//*
if(instance == null){
instance = new Singleton();
}
return instance;
}*/
/* —————————— —————————— 饿汉模式(内存浪费) —————————— —————————— */
/* *//*指向实例的私有静态引用,主动创建*//*
private static Singleton singleton = new Singleton();
*//*私有的构造方法*//*
private Singleton(){};
*//*以自己实例为返回值的静态的公有方法,静态工厂方法*//*
public static Singleton getSingleton(){
return singleton;
}*/
/* —————————— —————————— 双重锁模式(线程安全效率高) —————————— —————————— */
/* private volatile static Singleton singleton;
private Singleton(){};
private static Singleton getSingleton(){
*//*第一次是为了避免不要的实例*//*
if(singleton == null){
synchronized(Singleton.class){
*//*第二次是为了进行同步,避免多线程问题*//*
if(singleton == null){
*//*对象的创建在JVM中可能会进行重排序,使用了volatile关键字后,重排序被禁止*//*
singleton = new Singleton();
}
}
}
return singleton;
}*/
/* —————————— —————————— 静态内部类模式 —————————— —————————— */
/* private Singleton(){};
*//*只有第一次调用getInstance方法时,虚拟机才加载 Inner 并初始化instance ,
只有一个线程可以获得对象的初始化锁,其他线程无法进行初始化,保证对象的唯一性*//*
private static Singleton getInstance(){
return Inner.instance;
};
private static class Inner{
private static final Singleton instance = new Singleton();
}*/
}