当前位置: 首页 > news >正文

ReentrantLock 底层实现

一、核心概念

1 - CAS

CAS(Compare-And-Swap,比较并交换)操作是一种无锁的原子操作,它在多线程环境下能够保证线程安全,主要是通过硬件级别的原子性以及乐观锁的思想来实现的。以下详细介绍 CAS 操作保证线程安全的原理:

1. CAS 操作的基本概念

CAS 操作包含三个操作数:内存位置(V)、预期原值(A)和新值(B)。其操作过程如下:

  • 首先从内存位置 V 读取当前值。
  • 然后将读取到的值与预期原值 A 进行比较。
  • 如果当前值与预期原值相等,即 V == A,那么将内存位置 V 的值更新为新值 B。
  • 如果当前值与预期原值不相等,即 V != A,那么不进行更新操作,通常会返回失败信息。

在 Java 中,sun.misc.Unsafe 类提供了一些基于 CAS 的操作方法,例如 compareAndSwapIntcompareAndSwapLong 等,AtomicInteger 等原子类就是基于这些方法实现的。

2. 硬件级别的原子性

CAS 操作的原子性是由硬件保证的。在现代 CPU 中,CAS 操作是一个原子指令,这意味着在执行 CAS 操作时,不会被其他线程的操作所中断。例如,当一个线程执行 CAS 操作时,其他线程无法同时修改该内存位置的值,从而保证了操作的原子性。

以 AtomicInteger 的 incrementAndGet 方法为例(简化后的代码):

public final int incrementAndGet() {
    for (;;) {
        int current = get();
        int next = current + 1;
        if (compareAndSet(current, next))
            return next;
    }
}

public final boolean compareAndSet(int expect, int update) {
    return unsafe.compareAndSwapInt(this, valueOffset, expect, update);
}

在 incrementAndGet 方法中,通过不断尝试 CAS 操作来更新 AtomicInteger 的值。由于 CAS 操作的原子性,即使多个线程同时执行该方法,也不会出现数据竞争的情况。

3. 乐观锁的思想

CAS 操作基于乐观锁的思想,它假设在大多数情况下,线程在尝试更新数据时不会发生冲突。每个线程在更新数据之前,先检查内存中的值是否与自己预期的值相等,如果相等则进行更新,否则重试。

这种乐观的方式减少了线程之间的竞争,因为不需要像悲观锁(如 synchronized 关键字)那样在操作数据之前就锁定数据,从而提高了并发性能。例如,在一个多线程环境中,多个线程同时对一个共享变量进行自增操作,如果使用悲观锁,每次只有一个线程能够进行操作,其他线程需要等待;而使用 CAS 操作,多个线程可以同时尝试更新,只有在发生冲突时才需要重试,大大提高了并发效率。

4. 解决 ABA 问题

虽然 CAS 操作能保证线程安全,但存在 ABA 问题,即一个值原来为 A,被一个线程修改为 B,然后又被另一个线程修改回 A,此时 CAS 操作可能会误认为值没有被修改而成功更新。为了解决 ABA 问题,可以使用带有版本号的原子类(如 AtomicStampedReference),在每次修改值时同时更新版本号,这样在进行 CAS 操作时,不仅要比较值,还要比较版本号,从而避免 ABA 问题。

综上所述,CAS 操作通过硬件级别的原子性以及乐观锁的思想,在多线程环境下保证了线程安全,并且在提高并发性能方面具有很大的优势。

2 - AQS

3 - synchronized的对比

特性synchronizedReentrantLock
可重入性支持支持
锁类型非公平锁(无法指定公平性)可选择公平锁或非公平锁
锁的获取方式自动获取和释放(基于代码块)需手动调用 lock() 和 unlock()
中断响应不支持支持(lockInterruptibly()
超时获取锁不支持支持(tryLock(long, TimeUnit)
条件变量(Condition)通过 wait()/notify() 实现支持多个 Condition

相关文章:

  • 【git】【reset全解】Git 回到上次提交并处理提交内容的不同方式
  • AI智能体与大语言模型:重塑SaaS系统的未来航向
  • HTML篇
  • 区块链仿真工具SimBlock使用
  • PDF处理控件Aspose.PDF教程:使用 Python 将 PDF 转换为 TIFF
  • 【Spring】统一功能处理
  • Windows版FFmpeg使用及B站视频下载示例python源码
  • 本地部署流水账之ollama安装+Deepseek安装
  • Java中的并发工具类:CountDownLatch、CyclicBarrier、Semaphore详解
  • 怎么进行稀疏矩阵转化
  • 【STL学习】(6)list的模拟
  • 基于Spring Security 6的OAuth2 系列之二十三 - 高级特性--TLS客户端认证方法之二
  • 解密RAG系统排序优化:从基础原理到生产实践
  • 洛谷每日1题-------Day3__级数求和
  • KNN算法优化实战分享:从原理到工程化落地的深度解析
  • PowerShell 执行策略:fnm管理软件安装nodejs无法运行npm,错误信息:about_Execution_Policies
  • 279.完全平方数
  • 【python】01_写在前面的话
  • 【12】智能合约开发入门
  • 车载DoIP诊断框架 --- 连接 DoIP ECU/车辆的故障排除
  • 王日春已任教育部社会科学司司长,此前系人教社总编辑
  • 全国首例在沪完成,这项近视治疗手术不到10秒
  • 印媒证实:至少3架印军战机7日在印控克什米尔地区坠毁
  • 证监会主席吴清:我们资本市场最重要的特征是“靠谱”
  • 五一多城楼市火热:北京新房网签量同比翻倍,上海热门楼盘认购接连触发积分
  • 五一假期,新任杭州市委书记刘非到嘉兴南湖瞻仰红船