从Java内存模型讲双重检查锁原理

本文深入探讨了Java内存模型中的双重检查锁(DCL)原理,解释了为何原始DCL存在线程安全问题,并通过介绍重排序机制和happens-before规则,揭示了volatile关键字在确保可见性和禁止重排序方面的作用。最后,文章展示了如何利用volatile修正DCL,实现线程安全的单例模式。
摘要由CSDN通过智能技术生成

什么是双重检查锁?

双重检查锁(Double-Check Locking),顾名思义,通过两次检查,并基于加锁机制,实现某个功能。
要理解什么是双重检查锁,我们从常见的单例模式说起。看第一个例子:
未加锁的单例模式

上图中的单例模式一看就知道存在线程问题,如果两个线程:线程A和线程B,同时访问该类,线程A访问到第6行,在还没有实例化完成的时候,线程B访问到第5行,此时也会判断到instance=null,同样会执行实例化的代码,那么线程A和线程B就都会创建一个Singleton实例。

怎么解决上面出现的多线程并发访问导致的问题呢?

加锁!大家都知道,加锁是解决并发访问的方案,于是对代码进行修改,修改后如下:
同步后的单例模式

基于锁的相关特性,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值