AQS
AbstractQueuedSynchronizer
抽象同步队列简称AQS,它是实现同步器的基础组件,并发包中锁的底层就是使用AQS实现的
AQS是一个FIFO的双向队列,其内部通过节点 head
和 tail
记录队首和队尾元素,队列元素的类型为 Node
。
其中 Node中
的 thread
变量用来存放进入AQS队列里面的线程;
Node
节点内部的 SHARED
用来标记该线程是获取共享资源时被阻塞挂起后放入AQS队列的,
EXCLUSIVE
用来标记线程是获取独占资源时被挂起后放入AQS队列的;
waitStatus
记录当前线程等待状态,可以为 CANCELLED
(线程被取消了)、SIGNAL
(线程需要被唤醒)、CONDITION
(线程在条件队列里面等待)、PROPAGATE
(释放共享资源时需要通知其他节点);
prev
记录当前节点的前驱节点,next
记录当前节点的后继节点。
在AQS中维持了一个单一的状态信息 state
,可以通过 getState
、setState
、compareAndSetState
函数修改其值。
对于 ReentrantLock
的实现来说,state
可以用来表示当前线程获取锁的可重入次数;
对于读写锁 ReentrantReadWriteLock
来说,state
的高16位表示读状态,也就是获取该读锁的次数,低16位表示获取到写锁的线程的可重入次数;
对于 semaphore
来说,state
用来表示当前可用信号的个数;
对于 CountDownlatch
来说,state
用来表示计数器当前的值。