AQS的简单说明

1.概述

AQS全称AbstractQueuedSynchronizer,是用来实现 或者队列同步器 的公共基础部分的抽象实现,是整个JUC体系的基石 ,用于解决锁分配给谁的问题,ReentrantLock底层的实现就是AQS。

2.AQS实现原理

AQS内部有一个由volatile修饰(保证其可见性) 的变量state ,用此来表示锁是否被使用,初始化为0,当线程获取到锁时,state加1,此时当其他线程到来时,发现state为1,就会封装为NodeCLH变体的FIFO队列(先进先出的双向链表)中排队等待,等到占用锁的那个线程执行完毕,state减1,然后队列中等待的线程按顺序获取锁。

3.AQS内部类Node说明

在线程加入队列时要封装为Node,在Node中有一个表示线程的等待状态waitStatus,初始值为0。

4.AQS中acquire()方法的简单说明

4.1tryAcquire

这里运用了板块设计模式,tryAcquire方法的具体实现需要子类去实现。

4.2addWaiter

意思就是将此结点封装为Node结点,然后加入到队列中。

4.3acquireQueued

坐稳队列,在此方法中进行队列中前置结点状态的修改以及阻塞结点。

相关推荐
crossaspeed几秒前
Java-List,Set,Map(八股)
java·开发语言·list
LawrenceLan几秒前
Flutter 零基础入门(十八):StatefulWidget 生命周期初识
开发语言·前端·flutter·dart
虫小宝几秒前
基于责任链模式构建可扩展的微信群发消息风控过滤器(Java实现)
android·java·责任链模式
代码or搬砖1 分钟前
java并发编程
java·开发语言
小李独爱秋6 分钟前
计算机网络经典问题透视:IP电话的通话质量与哪些因素有关?
服务器·开发语言·网络·网络协议·tcp/ip·计算机网络
BHXDML9 分钟前
第九章: STL 容器基础(C++)
开发语言·c++
董世昌4112 分钟前
什么是暂时性死区?
开发语言·前端·javascript
茉莉玫瑰花茶17 分钟前
C++11 扩展 - 模板元编程
开发语言·c++
一起养小猫18 分钟前
智纺云ERP开发实战
java·css·sql·spring·html
毕设源码-钟学长20 分钟前
【开题答辩全过程】以 高校食堂管理系统为例,包含答辩的问题和答案
java