volatile + 双重检测机制 -> 禁止指令重排
package com.mmall.concurrency.example.singleton; import com.mmall.concurrency.annoations.ThreadSafe; /** * 懒汉模式 -> 双重同步锁单例模式 * 单例实例在第一次使用时进行创建 */ @ThreadSafe public class SingletonExample5 { // 私有构造函数 private SingletonExample5() { } // 1、memory = allocate() 分配对象的内存空间 // 2、ctorInstance() 初始化对象 // 3、instance = memory 设置instance指向刚分配的内存 // 单例对象 volatile + 双重检测机制 -> 禁止指令重排 private volatile static SingletonExample5 instance = null; // 静态的工厂方法 public static SingletonExample5 getInstance() { if (instance == null) { // 双重检测机制 // B synchronized (SingletonExample5.class) { // 同步锁 if (instance == null) { instance = new SingletonExample5(); // A - 3 } } } return instance; } }
- 在 V3 基础上,增加 volatile 禁止指令重排可以达到线程安全效果,但是还有更好的解决方案噢~