AQS是一个实现阻塞式锁的框架,ReentrantLock锁就是基于AQS实现的阻塞式锁。
AQS的原理:
(1)在AQS内部维护了一个用volatile修饰的state属性用来表示资源的状态,0表示无锁,1表示有锁。类似于monitor的owner属性。
(2)在AQS内部提供了一个FIFO的双向队列,用来存储没有获取到锁的线程,处于阻塞状态的线程。类似于monitor的EntryList。
(3)条件变量来实现等待、唤醒机制,支持多个条件变量,类似于 Monitor 的 WaitSet。