当前位置: 首页 > news >正文

【Java面试笔记:实战】41、Java面试核心考点!AQS原理及应用生态全解析

在这里插入图片描述

引言:AQS在Java并发体系中的核心地位

AQS(AbstractQueuedSynchronizer)作为Java并发包的底层基石,是理解ReentrantLock、Semaphore等同步工具的关键。

在Java架构师面试中,AQS的原理与应用是高频考点,掌握其核心机制对理解JUC包和构建高并发系统至关重要。

本文将从原理、应用、源码到Spring生态实践进行全面解析,帮助读者系统掌握这一核心技术。

一、AQS核心原理深度剖析

1.1 AQS的架构设计与核心组件

AQS是Java并发包中用于构建锁和同步器的抽象框架,其设计包含三大核心组件:

1.1.1 三大核心组件详解
组件名称技术实现核心作用
状态变量statevolatile int,通过CAS操作更新存储同步状态,不同场景含义不同(如锁重入次数、信号量许可数等)
CLH等待队列双向链表,由Node节点组成管理等待线程的FIFO顺序,实现线程阻塞与唤醒机制
模板方法抽象方法需子类实现定义同步逻辑接口(如tryAcquire、tryRelease等),实现模板方法模式
1.1.2 Node节点核心字段解析
static final class Node {// 节点状态:CANCELLED(1)、SIGNAL(-1)、CONDITION(-2)、PROPAGATE(-3)volatile int waitStatus;// 前驱节点引用volatile Node prev;// 后继节点引用volatile Node next;// 关联的线程volatile Thread thread;// 条件队列中的后继节点Node nextWaiter;
}
1.1.3 CLH队列结构示意图

在这里插入图片描述
CLH队列关键特性说明

  1. 双向链表结构
    • 每个节点包含 prevnext 指针
    • 头节点(Head)的prev为null
    • 尾节点(Tail)的next为null
  2. 节点内部结构
    static final class Node {volatile int waitStatus;  // 等待状态volatile Node prev;       // 前驱节点volatile Node next;       // 后继节点volatile Thread thread;   // 关联线程Node nextWaiter;          // 条件队列链接
    }
    
  3. 等待状态(waitStatus)
    • SIGNAL(-1):后继节点需要唤醒
    • CANCELLED(1):线程已取消
    • CONDITION(-2):在条件队列中
    • 0:初始状态
  4. 队列操作
    • 入队:尾插法(CAS更新Tail)
      // AQS中的入队代码
      private Node addWaiter(Node mode) {Node node = new Node(Thread.currentThread(), mode);Node pred = tail;if (pred != null) {node.prev = pred;if (compareAndSetTail(pred, node)) {pred.next = node;return node;}}enq(node); // CAS失败时自旋入队return node;
      }
      
    • 出队:头节点释放后唤醒后继
      // 唤醒后继节点
      private void unparkSuccessor(Node node) {int ws = node.waitStatus;if (ws < 0) compareAndSetWaitStatus(node, ws, 0);Node s = node.next;if (s == null || s.waitStatus > 0) {s = null;// 从尾向前查找有效节点for (Node t = tail; t != null && t != node; t = t.prev)if (t.waitStatus <= 0) s = t;}if (s != null) LockSupport.unpark(s.thread);
      }
      

1.2 AQS工作流程详解(独占模式)

1.2.1 核心执行流程

在这里插入图片描述

1.2.2 关键机制解析
  1. CAS无锁操作
    // AQS更新state的核心方法
    protected final boolean compareAndSetState(int expect, int update) {return unsafe.compareAndSwapInt(this, stateOffset, expect, update);
    }
    
    • 通过Unsafe类直接操作内存,确保原子性
    • stateOffset通过objectFieldOffset获取字段偏移量
  2. 线程阻塞与唤醒
    • 阻塞:LockSupport.park(this)
    • 唤醒:LockSupport.unpark(thread)
    • 基于Unsafe的park/unpark,比Object.wait/notify更高效
  3. 队列管理
    • 入队:CAS尾插法,保证线程安全
    • 出队:头节点释放后,将后继节点设为新头节点

二、AQS的同步模式与核心方法

2.1 独占模式(Exclusive Mode)

2.1.1 核心特性
  • 同一时刻仅允许一个线程获取资源
  • 典型实现:ReentrantLock、ReentrantReadWriteLock.WriteLock
  • 关键方法:
    • acquire(int arg):获取资源,失败则入队等待
    • release(int arg):释放资源,唤醒后继节点
2.1.2 状态流转图
tryAcquire成功
tryRelease成功
重入锁
未获取锁
获取锁

2.2 共享模式(Shared Mode)

2.2.1 核心特性
  • 允许多个线程同时获取资源
  • 典型实现:Semaphore、CountDownLatch、ReentrantReadWriteLock.ReadLock
  • 关键方法:
    • acquireShared(int arg):获取共享资源,失败入队
    • releaseShared(int arg):释放共享资源,可能唤醒后继
2.2.2 状态流转图

文章转载自:

http://eX8AI6pi.tckxL.cn
http://ejgjEiqe.tckxL.cn
http://I2JHHqzh.tckxL.cn
http://tvvzrQE6.tckxL.cn
http://oPnDzy5x.tckxL.cn
http://6BhcYIB1.tckxL.cn
http://Kq8myei4.tckxL.cn
http://2krf11Lg.tckxL.cn
http://8DZmE9Lb.tckxL.cn
http://jwtheerS.tckxL.cn
http://RitlFBi3.tckxL.cn
http://i6CliIDd.tckxL.cn
http://GEIcklNi.tckxL.cn
http://7edT358J.tckxL.cn
http://DhHKmBT7.tckxL.cn
http://CZoGo2mL.tckxL.cn
http://i2K4V3G5.tckxL.cn
http://NW6dRKlK.tckxL.cn
http://xGJHoHgI.tckxL.cn
http://0RH8SM9X.tckxL.cn
http://5HmbHBBF.tckxL.cn
http://TQwx1mKk.tckxL.cn
http://2vMJjLry.tckxL.cn
http://GQGipDUT.tckxL.cn
http://dSqdRtJH.tckxL.cn
http://lEi1BvKy.tckxL.cn
http://FaBuvqfW.tckxL.cn
http://eqtEzFrs.tckxL.cn
http://TqtCow45.tckxL.cn
http://C5DJljCA.tckxL.cn
http://www.dtcms.com/a/247199.html

相关文章:

  • 【亲测有效】MybatisPlus中MetaObjectHandler自动填充字段失效
  • 【cv学习笔记】YOLO系列笔记
  • 树莓派5 ubuntu 24.04 docker配置镜像Docker pull时报错:https://registry-1.docker.io/v2/
  • 海外广告投放|FB IG 速推帖子有效吗?
  • 测试过程中有哪些风险?
  • 3.4_1 流量控制、可靠传输与滑动窗口机制
  • 【Spring AI 1.0.0】Spring AI 1.0.0框架快速入门(2)——提示词
  • 简述Python里面search和match的区别
  • 【富士康租赁德克萨斯州工厂以扩大AI服务器产能】
  • Java并发编程实战 Day 20:响应式编程与并发
  • Windows 下安装 NVM
  • Mitsubishi GX Works3 / GOT3 的惡意工程混淆邏輯注入攻擊
  • Kratos 与Golang Cms的关系
  • 工具+服务双驱动:创客匠人打造中医IP差异化竞争力
  • Python 100个常用函数全面解析
  • firebase异常捕获
  • ChatGPT革命升级!o3-pro模型重磅发布:开启AI推理新纪元
  • Python Day49
  • 【QT】QVariant 转换为自定义的枚举类型
  • 关于联咏(Novatek )自动曝光中Lv值的计算方式实现猜想
  • 5 Android系统常用debug方法
  • Day 22
  • linux中执行脚本命令的source和“.”和“./”的区别
  • 前端开发冷知识-requestIdleCallback优化主线程任务调度的API
  • 大一计算机学习历程总结
  • 【25-cv-06400、25-cv-06413】Keith律所再次代理Elizabeth Anne Evans蝴蝶版权画
  • 算法学习的规范性和可持续性
  • ff数据解析和解码
  • 赛元微8051系列触控按键的开发
  • 进程间通信之消息队列