前言
Java编程学到并发这块,我们不得不提及ReentrantLock;而关于ReentrantLock,又要求我们必须要掌握好AQS!
目录
三、AQS对资源的共享方式
一、AQS简单介绍
何为AQS?AQS 的全称为 AbstractQueuedSynchronizer ,翻译过来的意思就是抽象队列同步器。AQS定义了一套多线程访问共享资源的同步器框架,许多同步类实现都依赖于它,如常用的 ReentrantLock/Semaphore/CountDownLatch ...。这个类在 java.util.concurrent.locks 包下面。
AQS就是一个 抽象类 ,主要用来 构建锁和同步器 。
public abstract class AbstractQueuedSynchronizer extends AbstractOwnableSynchronizer implements java.io.Serializable { }
AQS 为构建锁和同步器提供了一些通用功能的是实现,因此,使用 AQS 能简单且高效地构造出应用广泛的大量的同步器,比如我们提到的 ReentrantLock , Semaphore , 其他的诸如 ReentrantReadWriteLock , SynchronousQueue , FutureTask(jdk1.7) 等等皆是基于 AQS 的。
二、AQS原理及框架
AQS 核心思想是, 如果被请求的共享资源空闲,则将当前请求资源的线程设置为有效的工作线程,并且将共享资源设置为锁定状态 。如果被请求的共享资源被占用,那么就需要一套线程阻塞等待以及被唤醒时锁分配的机制,这个机制 AQS 是用 CLH 队列锁 实现的,即 将暂时获取不到锁的线程加入到队列中 。
CLH(Craig,Landin,and Hagersten)队列是一个虚拟的双向队列(虚拟的双向队列即不存在队列实例,仅存在结点之间的关联关系)。