Java并发编程-AQS详解及案例实战(上篇)

文章目录

  • AQS概述
      • AQS 的核心概念
      • AQS 的工作原理
      • AQS 的灵活性
      • 使用场景
  • AQS的本质:为啥叫做异步队列同步器
      • AQS的核心机制
      • “异步队列”的含义
      • “同步器”的含义
      • 总结
  • 加锁失败的时候如何借助AQS异步入队阻塞等待
      • AQS的锁队列
      • 加锁失败时的处理流程
      • 异步入队的机制
      • 总结
  • ReentractLock如何设置公平锁策略以及原理
      • 设置公平锁策略
      • 公平锁的运作原理
        • 尝试获取锁
        • 释放锁
      • 性能与公平性的权衡
  • tryLock如何实现加锁等待一段时间过后放弃
      • tryLock的基本用法
      • tryLock的实现原理
      • 实现示例
      • 总结
  • ReentractLock底层如何实现
      • ReentrantLock的实现原理
      • ReentrantLock与AQS的关系
  • 用第三个线程尝试加锁失败彻底图解AQS队列等待机制
      • 场景设定
      • Thread C尝试获取锁
      • Thread C加入等待队列
      • Thread C被阻塞
      • 图解
      • 总结
  • AQS默认的非公平加锁策略的运作原理
      • 非公平锁的运作原理
        • 尝试获取锁
        • 重新获取锁
        • 等待队列中的线程
      • 总结
  • 服务注册中心的最近更新服务实例队列实现
      • 设计思路
      • 实现示例
      • 注意事项
  • 服务注册中心提供全量和增量拉取注册表的接口
      • 全量拉取
        • 实现思路:
        • 示例代码(使用Spring Boot):
      • 增量拉取
        • 实现思路:
        • 示例代码(使用Spring Boot):
      • 注意事项
  • 客户端实现启动时拉取全量注册表
      • 步骤 1: 添加依赖
      • 步骤 2: 创建配置类
      • 步骤 3: 实现全量拉取逻辑
      • 步骤 4: 在启动时执行全量拉取
      • 注意事项
  • 案例实战:客户端实现定时拉取增量注册表到本地合并
      • 业务需求
      • 使用AQS设计定时任务
      • 实现步骤
      • 代码示例
      • 注意事项
  • 案例实战:增量合并注册表后进行校验与全量纠正
      • 业务需求
      • AQS辅助设计
      • 实现步骤
      • 代码示例
      • 注意事项
  • AQS如何基于无锁化的CAS机制实现高性能的加锁
      • CAS机制
      • AQS中的CAS应用
        • 获取锁
        • 释放锁
      • 无锁化的优势
  • 如何巧妙的借助AQS中的state变量实现可重入式加锁
      • 可重入锁的基本原理
      • 利用AQS实现可重入锁
      • 示例代码
  • 基于AQS实现的可重入锁释放过程的源码剖析
      • AQS中的锁释放逻辑
      • ReentrantLock的`unlock`方法
      • AQS的`release`方法
      • AQS的`tryRelease`方法
      • 唤醒等待线程
      • 总结
  • 锁释放过后如何对AQS队列中唤醒阻塞线程尝试抢占锁
      • AQS的唤醒机制
      • 唤醒等待线程
      • `unparkSuccessor`方法详解
      • 尝试抢占锁
      • 总结
  • 一种新奇的加锁玩法:读锁和写锁分开是怎么玩的
      • 读写锁的原理
      • 使用场景
      • Java中的读写锁实现
      • 总结
  • 读写锁中的写锁是如何基于AQS的state变量完成加锁的
      • AQS的`state`变量
      • 写锁加锁过程
      • 代码示例
      • 总结
  • 基于AQS的state二进制高低16位判断实现写锁的可重入加锁
      • `state`变量的位分配
      • 写锁的可重入加锁
      • 代码实现
      • 总结
  • 写锁加锁失败时如何基于AQS队列完成入队阻塞等待?
      • 尝试获取写锁
      • 加锁失败后的处理
      • 加入AQS队列
      • 阻塞线程
      • 监听锁状态变化
      • 队列中的线程唤醒
      • 总结
  • 读写锁互斥:基于AQS的state二进制高低16位完成互斥判断
      • `state`变量的位分配
      • 互斥判断
      • 代码示例
      • 互斥性的保证
      • 总结

AQS概述

AQS,全称 AbstractQueuedSynchronizer,是 Java 并发包 java.util.concurrent.locks 中的一个抽象类,它为实现依赖于先进先出(FIFO)等待队列的阻塞锁和其他同步器提供了基础框架。AQS 是 Java 内置锁和大部分并发工具类(如 ReentrantLock, Semaphore, CountDownLatch 等)的基础,通过它我们可以理解 Java 高级并发工具的内部工作原理。

AQS 的核心概念

  1. 独占式与共享式同步

    • 独占式:一次只有一个线程可以获取同步状态,如 ReentrantLock。
    • 共享式:多个线程可以同时获取同步状态,如 Semaphore。
  2. 状态管理

    • AQS 使用一个 int 成员变量来表示同步状态,通过内置的 Unsafe 类的原子操作方法来修改这个状态,保证线程安全。
  3. CLH 锁队列

    • CLH(Craig-Landin-Hagersten)队列是一种高性能的非阻塞队列,AQS 使用 CLH 锁队列来管理等待线程,当线程尝试获取锁而未能成功时,会被加入到队列中。

AQS 的工作原

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C语言实现顺序表字符型数据排序

实现直接插入、冒泡、直接选择排序算法。 #include <stdio.h> #include <stdlib.h>typedef char InfoType;#define n 10 //假设的文件长度&#xff0c;即待排序的记录数目 typedef char KeyType; //假设的关键字类型 typedef struct { //记录类型KeyType…

最小权顶点覆盖问题-优先队列分支限界法-C++

问题描述: 给定一个赋权无向图 G(V,E)&#xff0c;每个顶点 v∈V 都有一个权值 w(v)。如果 U⊆V&#xff0c;U⊆V&#xff0c;且对任意(u,v)∈E 有 u∈U 或 v∈U&#xff0c;就称 U 为图 G 的一个顶点覆盖。G 的最小权顶点覆盖是指 G 中所含顶点权之和最小的顶点覆盖。对于给定…

干货分享 | HTTP代理与SOCKS5代理的优缺点

本次我们来聊聊HTTP代理和SOCKS5代理这两种常见的代理协议。了解它们的优缺点和搭建方法&#xff0c;可以帮助你在各种应用场景中选择最合适的代理方式。让我们一起来探索吧&#xff01; HTTP代理的优缺点 优点&#xff1a; 简单易用&#xff1a;HTTP代理主要用于处理HTTP协…

代码随想录算法训练营第23天|LeetCode 39. 组合总和、40.组合总和II、131.分割回文串

1. LeetCode 39. 组合总和 题目链接&#xff1a;https://leetcode.cn/problems/combination-sum/description/ 文章链接&#xff1a;https://programmercarl.com/0039.组合总和.html 视频链接&#xff1a;https://www.bilibili.com/video/BV1KT4y1M7HJ 思路&#xff1a; 本题和…

Java多语言跨境电商外贸商城源码 tiktok商城系统源码 跨境电商源码

Java多语言跨境电商外贸商城源码 tiktok商城系统源码 跨境电商源码 技术栈 PC端使用&#xff1a;vueelementui 用户端使用&#xff1a;uniapp 管理端使用&#xff1a;vueelementui 后台服务使用&#xff1a;springbootmybatisplusmysql 功能描述&#xff1a; 对接PayPal…

统计是一门艺术(非参数假设检验)

1.定义 当总体分布未知&#xff0c;那么就需要一种与分布具体数学形式无关的统计推断方法&#xff0c;称为非参数方法 只能利用样本中的一般信息包括位置和次序关系等 稳健性强 2.符号检验 考虑问题&#xff1a; 小样本情况&#xff1a; 以概率为1/2的二项分布是对称的 两…

idea部署war包成功,但是接口404

场景 项目结构 xxx-xxx-app xxx-xxx-service xxx-xxx-webappapp/webapp依赖service&#xff0c;service中写了各种api&#xff0c;先别管它合不合理&#xff0c;正式环境用webapp发布。 本地配置tomcat启动&#xff0c;但是发现每次部署成功&#xff0c;但是service中的接口…

使用Ubuntu 22.04安装Frappe-Bench【二】

系列文章目录 第一章 使用VMware创建Ubuntu 22.04【一】 文章目录 系列文章目录前言什么是Frappe-Bench&#xff1f;使用安装ERPNext能实现什么效果&#xff1f; 官网给了一个说明 一、使用Ubuntu 22.04安装Frappe-Bench一、安装要求二、安装命令三、 可能出现问题 总结 前言 …

hnust 1816: 算法10-9:简单选择排序

hnust 1816: 算法10-9&#xff1a;简单选择排序 题目描述 选择排序的基本思想是&#xff1a;每一趟比较过程中&#xff0c;在n-i1(i1,2,…,n-1)个记录中选取关键字最小的记录作为有序序列中的第i个记录。 在多种选择排序中&#xff0c;最常用且形式最为简单的是简单选择排序。…

JavaScript中的立即执行函数表达式(Immediately Invoked Function Expression, IIFE)

聚沙成塔每天进步一点点 本文回顾 ⭐ 专栏简介JavaScript中的立即执行函数表达式&#xff08;Immediately Invoked Function Expression, IIFE&#xff09;1. 引言2. IIFE的概念2.1 概述2.2 语法2.3 历史背景 3. IIFE的作用3.1 创建独立作用域3.2 模块化代码3.3 防止变量提升3.…

动态路由--RIP配置(思科cisco)

一、简介 RIP协议&#xff08;Routing Information Protocol&#xff0c;路由信息协议&#xff09;是一种基于距离矢量的动态路由选择协议。 在RIP协议中&#xff0c;如果路由器A和网络B直接相连&#xff0c;那么路由器A到网络B的距离被定义为1跳。若从路由器A出发到达网络B需要…

Apache Seata分布式事务启用Nacos做配置中心

本文来自 Apache Seata官方文档&#xff0c;欢迎访问官网&#xff0c;查看更多深度文章。 本文来自 Apache Seata官方文档&#xff0c;欢迎访问官网&#xff0c;查看更多深度文章。 Seata分布式事务启用Nacos做配置中心 Seata分布式事务启用Nacos做配置中心 项目地址 本文作…

FreeU: Free Lunch in Diffusion U-Net——【代码复现】

这篇文章发表于CVPR 2024&#xff0c;官网地址&#xff1a;ChenyangSi/FreeU: FreeU: Free Lunch in Diffusion U-Net (CVPR2024 Oral) (github.com) 一、环境准备 提前准备好python、pytorch环境 二、下载项目依赖 demo下有一个requirements.txt文件&#xff0c; pip inst…

Fill - UVA 10603

网址如下&#xff1a; Fill - UVA 10603 - Virtual Judge (vjudge.net) 感觉有点浮躁&#xff0c;没法完全将思绪投入题的思考中 脑袋糊糊的 一道bfs题 代码如下&#xff1a; #include<queue> #include<cstdio> #include<cstring> #include<vector&g…

开放式耳机哪个牌子好?悠律、漫步者、韶音全面对比与推荐

对于现在的无线耳机市场而言&#xff0c;开放式耳机迎来的真正的大爆发&#xff0c;关键的是它采用了定向传声方式&#xff0c;我们在运动时除了可以感受到音乐带来的快乐外&#xff0c;还能时刻保持对外界环境音的警觉。 今天&#xff0c;我们将为大家详细对比推荐三款备受瞩…

Redis中list类型操作命令(操作演示、命令语法、返回值、时间复杂度、注意事项等)

文章目录 lpush 命令lrange 命令lpushx 命令rpush 命令rpushx 命令lpop 命令rpop 命令lindex 命令linsert 命令llen 命令lrem 命令ltrim 命令lset 命令blpop 和 brpop lpush 命令 从左侧向列表中插入指定的元素 语法&#xff1a;lpush key value [value……] 时间复杂度&#…

大厂面试官赞不绝口的后端技术亮点【后端项目亮点合集(2)】

本文将持续更新~~ hello hello~ &#xff0c;这里是绝命Coding——老白~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#xff1a;绝命C…

第三方商城对接重构(HF202407)

文章目录 项目背景一、模块范围二、问题方案1. 商品模块整体来说这块对接的不是太顺利,梳理了几条大概的思路:2. 订单模块3. 售后4. 发票5. 结算单经验总结项目背景 作为供应商入围第三方商城成功,然后运营了一段时间,第三方通知要重构, 需要重新对接打通接口完成系统对接…

【网络管理工具】NETworkManager工具的基本使用教程

【网络管理工具】NETworkManager工具的基本使用教程 一、NETworkManager工具介绍1.1 NETworkManager简介1.2 NETworkManager特点1.3 NETworkManager使用场景 二、下载NETworkManager软件包2.1 下载地址2.2 下载软件 三、运行NETworkManager工具3.1 解压NETworkManager3.2 运行N…

WPF中Background=“{x:Null}“ 和 Transparent

WPF中关于背景透明和背景无 此时&#xff0c;我代码中是写的有有个控件&#xff0c;一个Border &#xff0c;一个TextBox &#xff0c;范围都是全屏这么大&#xff0c;可以输入TextBox 因为&#xff0c;当border没有设置背景的时候&#xff0c;实际上是&#xff1a; <Borde…