AQS AbstractQueuedSynchronizer源码分析

本文详细剖析了Java并发库中的AQS(AbstractQueuedSynchronizer)的设计与实现,包括其使用、队列原子操作、结构、AQS实现、线程挂起与唤醒、条件等待与通知等内容。通过分析,读者可以理解AQS如何为并发工具如ReentrantLock、Semaphore提供同步基础,并掌握其核心原理。
摘要由CSDN通过智能技术生成

在解决并发问题时,开发者需要各种同步功能进行线程间的通信、协调、控制,比如信号量、锁、条件等待通知等等。
JDK提供了AQS作为实现这些同步器(synchronizer)的基础,jdk中的并发工具类比如ReentrantLock, Semaphore, CountDownLatch等都是使用AQS来实现各自的线程同步能力的。

AQS因为方法命名比较抽象,导致很多朋友开始难以理解各个方法的作用、原理,不用担心,通过学习本文今天我们彻底掌握AQS。

AQS使用

AQS整体实现设计

AQS把同步器的操作分成两个操作,分别是acquire获取和release释放。
acquire和release操作的对象是AQS中的state变量。

比如对于锁来说,加锁对应acquire,释放锁对应release;对于Semaphore信号量来说,获取permit对应acquire,释放permit对应release。

在实现具体的同步器时,需要实现tryAcquire和tryRelease。
tryAcquire定义了获取成功的定义,比如在ReentrantLock中,state为0表示未加锁,大于0表示已加锁, tryAcquire就需要定义如何操作state表示当前线程获得了锁。
AQS中state字段是一个volatile的int实例字段&#x

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

高级Java进阶之路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值