Java之AQS(AbstractQueuedSynchronizer)

Java之AQS(AbstractQueuedSynchronizer

AQS 介绍

AQS 的全称为 AbstractQueuedSynchronizer ,翻译过来的意思就是抽象队列同步器。这个类在 java.util.concurrent.locks 包下面。

image.png

● 是用来实现锁或者其他同步器组件的公共基础部分的抽象实现
● 是重量级基础框架及整个JUC体系的基石,主要用于解决锁分配给”谁“的问题。
● 整体就是一个抽象的FIFO队列来完成资源获取线程的排队工作,并通过一个int类变量表示持有锁的状态

public abstract class AbstractQueuedSynchronizer extends AbstractOwnableSynchronizer implements java.io.Serializable {
}

AQS 为构建锁和同步器提供了一些通用功能的实现,因此,使用 AQS 能简单且高效地构造出应用广泛的大量的同步器,比如我们提到的 ReentrantLock,Semaphore,其他的诸如 ReentrantReadWriteLock,SynchronousQueue等等皆是基于 AQS 的

image.png

image.png

AQS为什么是JUC内容中最重要的基石

和AQS有关的

image.png

ReentrantLock

image.png

CountDownLatch

image.png

● 进一步理解锁和同步器的关系
○ 锁,面向锁的使用者:定义了程序员和锁交互的使用层API,隐藏了实现细节,你调用即可
○ 同步器,面向锁的实现者:Java并发大神DoungLee,提出了统一规范并简化了锁的实现,将其抽象出来,屏蔽了同步状态管理、同步队列的管理和维护、阻塞线程排队和通知、唤醒机制等,是一切锁和同步组件实现的----公共基础部分

AQS 核心思想

AQS 核心思想是,如果被请求的共享资源空闲,则将当前请求资源的线程设置为有效的工作线程,并且将共享资源设置为锁定状态。如果被请求的共享资源被占用,那么就需要一套线程阻塞等待以及被唤醒时锁分配的机制,这个机制 AQS 是基于 CLH 锁变体 (Craig, Landin, and Hagersten locks) 实现的。

CLH 锁是对自旋锁的一种改进,是一个虚拟的双向队列(虚拟的双向队列即不存在队列实例,仅存在结点之间的关联关系),暂时获取不到锁的线程将被加入到该队列中。AQS 将每条请求共享资源的线程封装成一个 CLH 队列锁的一个结点(Node)来实现锁的分配。在 CLH 队列锁中,一个节点表示一个线程,它保存着线程的引用(thread)、 当前节点在队列中的状态(waitStatus)、前驱节点(prev)、后继节点(next)。

CLH 队列结构如下图所示:

CLH 队列结构

AQS(AbstractQueuedSynchronizer)的核心原理图:

CLH 队列

AQS内部体系架构----AQS自身

  • AQS的int类型变量state

    • AQS的同步状态State成员变量

image.png

另外,状态信息 state 可以通过 protected 类型的getState()setState()compareAndSetState() 进行操作。并且,这几个方法都是 final 修饰的,在子类中无法被重写。

//返回同步状态的当前值
protected final int getState() {return state;
}// 设置同步状态的值
protected final void setState(int newState) {state = newState;
}
//原子地(CAS操作)将同步状态值设置为给定值update如果当前同步状态的值等于expect(期望值)
protected final boolean compareAndSetState(int expect, int update) {return unsafe.compareAndSwapInt(this, stateOffset, expect, update);
}
------
著作权归JavaGuide(javaguide.cn)所有
基于MIT协议
原文链接:https://javaguide.cn/java/concurrent/aqs.html

著作权归JavaGuide(javaguide.cn)所有 基于MIT协议 原文链接:https://javaguide.cn/java/concurrent/aqs.html

  • AQS的CLH队列

    • CLH(三个大牛的名字组成)队列为一个双向队列

image.png

AQS内部体系架构----内部类Node

  • Node的int变量

    • Node的等待状态waitState成员变量
    • image.png
    • 说人话
      • 等候区其他顾客(其他线程)的等待状态
      • 队列中每个排队的个体就是一个Node
  • Node此类的讲解

    • 内部结构

image.png

image.png

以Reentrantlock的实现来分析AQS的原理及应用

由于篇幅过长放在下一篇文章中

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/298737.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

类和对象的创建和实例化

1. 类的概述 1.1 具体示例 类是描述一类事物的特征和行为的统称,抽象的不存在的,泛指的概念,例如:描述一个人,从外观上(特征)和言行举止(行为)上进行描述外观上&#xff…

【Java】MybatisPlus

MybatisPlus MybatisPlus是在mybatis基础上的一个增强型工具。它对mybatis的一些操作进行了简化,能够提高开发的效率。 springboot整合了mybatis之后,其实已经非常方便了,只需要导入mybatis的包后,在配置文件中编写数据源信息&a…

10个得心应手的数据网站,助你完成数据科学项目

本文将介绍10个获取所需数据的网站,助力数据科学项目。 当你的数据对你来说很枯燥或毫无意义时,要激励自己学习数据科学,或做数据科学项目真的很困难。 本文将介绍10个得心应手的网站,在这些网站上你可以为数据科学项目获取一些非…

计算机视觉基础(12)——图像恢复

前言 我们将学习图像恢复相关知识。主要有图像恢复的定义、评价标准和实现图像恢复的方法。图像恢复任务包括图像去噪、去模糊、图像超分辨率、图像修复等;评价标准有峰值信噪比和结构相似性;图像超分辨的方法有传统方法和基于深度学习的方法&#xff1a…

[Ray Tracing: The Next Week] 笔记

前言 本篇博客参照自《Ray Tracing: The Next Week》教程,地址为:https://raytracing.github.io/books/RayTracingTheNextWeek.html 该教程在ray tracing in one weekend的基础上,增加了运动模糊、BVH树、Texture映射、柏林噪声、光照、体积…

做外贸其实也并没有那么容易

最近无意中看到一个视频,视频的内容是外贸博主和一个连线人的对话,连线人的诉求是如何做外贸?怎么能把外贸做好, 通过博主和这个人的沟通来看,这个连线的人他从来没有接触过外贸,也不愿意去别的外贸公司上…

【Vulnhub 靶场】【Funbox: Under Construction!】【简单】【20210719】

1、环境介绍 靶场介绍:https://www.vulnhub.com/entry/funbox-under-construction,715/ 靶场下载:https://download.vulnhub.com/funbox/Funbox10.ova 靶场难度:简单 发布日期:2021年07月19日 文件大小:1.3 GB 靶场作…

宋仕强论道之华强北山寨手机(三十)

要研究透彻深圳华强北,华强北的“山寨手机”是绕不过去的话题。它来的轰轰烈烈,造就华强北几十个亿万富翁,去的鼠头蛇尾留下一地鸡毛。其兴也勃焉,其亡也忽焉!在华强北留下了财富的传奇故事,和失意者发疯跳…

ClickHouse 入门与实战教程

目录 1. ClickHouse 简介 什么是 ClickHouse? ClickHouse 的优势和特点 适用场景 2. 安装 ClickHouse 3. ClickHouse 的基本概念 4. ClickHouse 的基本操作 创建数据库和表、插入和查询数据 使用 MergeTree 引擎处理时序数据 管理分区 创建带有分区的 Mer…

RPA数据统计与展示

随着企业RPA机器人部署规模越来越庞大,更需要完善精细的管理与规划。这些进行自动化工作的数字员工,就像是传统的真实员工一样,也需要对日常的工作做好管理,对未来的发展做好规划,要实现这点,首先需要对RPA…

高精度电流源原理是什么

高精度电流源是一种能够提供准确、稳定的电流输出的设备。它被广泛应用于工业自动化、科学研究和仪器仪表等领域,用于检测、校准和驱动其他设备。 高精度电流源的原理是基于反馈控制和精密电路设计。下面西安安泰电子将详细介绍高精度电流源的原理。 高精度电流源包…

智能优化算法应用:基于金豺算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用:基于金豺算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用:基于金豺算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.金豺算法4.实验参数设定5.算法结果6.参考文献7.MA…