抽象的队列同步器
AQS从字面上理解是 抽象的队列同步器
- 是用来构建锁或者其它同步器组件的重量级基础框架及整个JUC体系的基石
- 通过内置的FIFO(先进先出)队列来完成资源获取线程的排队工作,并通过一个int类变量 表示持有锁的状态
锁和同步器的关系
对于我们调用的那些Api,像什么ReentrantLock,CountDownLatch,Smeaphore 等等 他们底层具体如何如何实现 上锁等待,解锁唤醒,都是依赖于AQS的统一管理
- 锁,面向锁的使用者 :定义了程序员和锁交互的使用层API,隐藏了实现细节,你调用即可。
- 同步器,面向锁的实现者 :规范并简化了锁的实现,屏蔽同步状态管理、阻塞线程排队和通知、唤醒机制等。
AQS的任务
资源上锁,会导致一些线程阻塞, AQS的任务就是 管理这些等待线程,并且在资源解锁后,负责去唤醒等待线程
AQS实现的步骤
- AQS使用 一个volatile的int类型的成员变量 来表示 同步状态
- 通过内置的 FIFO队列 来完成资源获取的排队工作 , 将每条要去抢占资源的线程封装成 一个Node节点来实现锁的分配,通过CAS完成对State值的修改