概念
AbstractQueuedSynchronizer抽象类(以下简称AQS)是整个java.util.concurrent包的核心。在JDK1.5时,Doug Lea引入了J.U.C包,该包中的大多数同步器都是基于AQS来构建的。AQS框架提供了一套通用的机制来管理同步状态(synchronization state)、阻塞/唤醒线程、管理等待队列。如常用的 ReentrantLock/Semaphore/CountDownLatch都是依赖于它。
AQS框架,分离了构建同步器时的一系列关注点,它的所有操作都围绕着资源——同步状态(synchronization state)来展开,并替用户解决了如下问题:
- 资源是可以被同时访问?还是在同一时间只能被一个线程访问?(共享/独占功能)
- 访问资源的线程如何进行并发管理?(等待队列)
- 如果线程等不及资源了,如何从等待队列退出?(超时/中断)
AQS框架将剩下的一个问题留给用户:
什么是资源?如何定义资源是否可以被访问?
这其实是一种典型的模板方法设计模式:父类(AQS框架)定义好骨架和内部操作细节,具体规则(比如资源的获取/释放方式)由子类去实现。

AQS(AbstractQueuedSynchronizer)是Java并发编程中的核心类,用于构建锁和同步器。它通过维护一个同步状态并管理线程的阻塞与唤醒,实现了独占和共享两种资源访问模式。在AQS中,线程通过CLH队列进行等待,当资源可用时,线程被唤醒。ReentrantLock、Semaphore和CountDownLatch等并发工具类都是基于AQS实现的。
最低0.47元/天 解锁文章
1347

被折叠的 条评论
为什么被折叠?



