AQS第一篇 —— AQS为什么是JUC内容中最重要的基石?

抽象的队列同步器

AQS从字面上理解是 抽象的队列同步器

在这里插入图片描述

  1. 是用来构建锁或者其它同步器组件的重量级基础框架及整个JUC体系的基石
  2. 通过内置的FIFO(先进先出)队列来完成资源获取线程的排队工作,并通过一个int类变量 表示持有锁的状态

锁和同步器的关系

对于我们调用的那些Api,像什么ReentrantLock,CountDownLatch,Smeaphore 等等 他们底层具体如何如何实现 上锁等待,解锁唤醒,都是依赖于AQS的统一管理

  1. 锁,面向锁的使用者 :定义了程序员和锁交互的使用层API,隐藏了实现细节,你调用即可。
  2. 同步器,面向锁的实现者 :规范并简化了锁的实现,屏蔽同步状态管理、阻塞线程排队和通知、唤醒机制等。

AQS的任务

资源上锁,会导致一些线程阻塞, AQS的任务就是 管理这些等待线程,并且在资源解锁后,负责去唤醒等待线程

AQS实现的步骤

  1. AQS使用 一个volatile的int类型的成员变量 来表示 同步状态
  2. 通过内置的 FIFO队列 来完成资源获取的排队工作 , 将每条要去抢占资源的线程封装成 一个Node节点来实现锁的分配,通过CAS完成对State值的修改

在这里插入图片描述

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_45844836/article/details/112514682