懒汉式单例模式为什么要进行二次判空

本文详细介绍了 Java 中实现 Singleton 模式的双重检查锁定(Double-Check Locking)方法,通过 volatile 关键字防止指令重排序,并使用两次判空检查避免多线程环境下创建多个 Singleton 实例。此实现保证了线程安全,同时优化了性能。
摘要由CSDN通过智能技术生成
public class Singleton {
    // volatile 保证可见性和禁止指令重排序 
    private static volatile Singleton singleton;
	
  // 将构造器的修饰符设置为"private",可以防止在外部进行new实例对象
    private Singleton() {
    };
	
    public static Singleton getInstance() {
        // 第一次检查
        if (singleton == null) {
          // 同步代码块
          synchronized(this.getClass()) {
              // 第二次检查
              if (singleton == null) {
                    // 对象的实例化是一个非原子性操作
                    singleton = new Singleton();
                }
            }
        }
        return singleton;
    }
}

如果不进行第二次判空的话,那么在竟锁池((锁池)中如果还有活跃的线程在等待获取的锁的话,在锁释放后就会再次竞争获取锁,获取的锁的线程进入"就绪状态",当CPU分配其"时间片"后进行线程的调度,从而线程进入"运行中状态",并会去执行同步的代码块,如果在没加如二次判空的话,就会导致系统中存在多个实例,而在进行判空后,即使你获取到了锁,但在执行同步代码块时也会直接跳过。

第一次判空是非必须的(优化)  第二次判空是必须的
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值