懒汉式单例模式双重检测锁的理解
程序员文章站
2024-02-29 19:33:04
...
public class Singleton {
//volatile 防止指令重排 和可见性
private volatile static Singleton uniqueInstance;
private Singleton() {
}
public Singleton getUniqueInstance() {
//先判断对象是否已经实例化过,没有实例化才进入加锁代码
if (uniqueInstance == null) {
//类对象加锁
synchronized (Singleton.class) {
//避免 singleTon== null时,第一个线程实例化后,进入阻塞状态的线程被唤醒后仍会进行实例化。
if (uniqueInstance == null){
uniqueInstance = new Singleton();
}
}
}
return uniqueInstance;
}
}
- 第一个 if (uniqueInstance == null) 是为了判断对象是否已经实例化,只有非实例化的情况下才能进入if块进行加锁。
- 第二个if(uniqueInstance == null) 是因为:假设存在线程1和线程2,当第一次实例化时,他们都能进入到第一个if块中,当线程1获取到Singleton的锁,由于此时uniqueInstance 还未加载可以进入第二个if块,当执行完
uniqueInstance = new Singleton();
便返回 uniqueInstance,此时uniqueInstance已经实例化,但是此时线程2获得锁,如果没有第二个if块则会再次new 一个新的实例出来,就违反了单例的规则。