java并发的AQS

what:

  AQS的全称是AbstractQueuedSynchronizer,即抽象队列同步器,其底层是volatile与CAS。而其上层则是基于该抽象类构建的许多并发组件,如ReentrantLock、Semaphore等。 

  

  AQS最核心的数据结构是一个volatile int state 和 一个FIFO线程等待对列。state代表共享资源的数量,如果是互斥访问,一般设置为1,而如果是共享访问,可以设置为N(N为可共享线程的个数);而线程等待队列是一个双向链表无法立即获得锁而进入阻塞状态的线程会加入队列的尾部。当然对state以及队列的操作都是采用了:“volatile + CAS + 自旋”的操作方式,采用的是乐观锁的概念。

  volatile见文章:https://www.cnblogs.com/sfzlstudy/p/16191700.html

  CAS见文章:https://www.cnblogs.com/sfzlstudy/p/16335240.html

 

  AQS有两种实现方式,一种是独占方式,另一种是共享方式(shared),取决于用户实现什么方法。AQS的线程等待队列图,如下图:

 

posted @ 2022-06-01 18:09  修心而结网  阅读(38)  评论(0编辑  收藏  举报