位置: IT常识 - 正文

并发基础之AQS(并发操作的定义)

编辑:rootadmin
并发基础之AQS

目录

什么AQS

AQS原理

重点1:CLH队列​

重点2:state 状态

AQS 两种资源共享方式

1) Exclusive(独占)

2) Share(共享)

AQS 模板方法运用

补充知识CAS

CAS的优点

CAS的缺点

缺点解决办法

总结


什么AQS

推荐整理分享并发基础之AQS(并发操作的定义),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:并发api,并发操作的定义,并发设计,并发操作的三类问题,并发算法,并发算法,并发技术,并发的基础,内容如对您有帮助,希望把文章链接给更多的朋友!

AQS是位于java.util.concurrent.locks 包下的 AbstractQueuedSynchronizer类,是构建同步器和锁的基础框架。我们可以通过继承AbstractQueuedSynchronizer 创建自己的同步器。比如我们常用的JUC并发包下面的CountDownLatch、ReentrantLock、Semaphore等等都是源于AQS实现的并发工具类。

AQS原理

核心思想是多个线程访问共享资源,如果一个线程发现共享资源没有被占用,则将资源设定为锁定状态且当前线程设为占用线程,如果一个线程发现共享资源已经被占用,则需要等待占用线程释放资源,当然当占用线程释放资源的时候AQS会通知其他等待线程进行资源抢占。在AQS实际源码中是通过state 状态在标识资源是否占用,通过CLH FIFO虚拟双向队列来实现将最近的等待线程放在队列末尾。

重点1:CLH队列

如图所示CLH是一个虚拟的双向队列,是通过state的值实现线程等待排序在队列末尾。队列head 头部是当前资源占用工作线程,node1-node n 则是资源被锁定后等待的线程节点。在实际的资源占用过程中,根据是否公平锁来确定是顺序占用资源和抢占式占用资源。

重点2:state 状态

如上图所示,线程获取资源是否被占用是通过获取 state 状态来实现。AQS源码已经给出获取、设置、通过CAS修改state 的方法。此时我们可以理解为:

 1、线程获取state 发现为 0 ,说明没有线程占用则占用该资源,并通过CAS将state 置为 1

2、如果该线程有重入的情况则继续增加state 的值,重入几次就增加几次

3、线程出方法则需要释放state值,也就是减少state

4、当state值为0 的时候标识线程执行完毕解除占用,此时AQS唤醒其他线程可以占用资源

AQS 两种资源共享方式1) Exclusive(独占)

只有一个线程能执行,如 ReentrantLock。又可分为公平锁和非公平锁,ReentrantLock 同时支持两种锁。根据ReentrantLock定义,我们可知公平锁是根据队列的等待顺序占用资源,非公平锁是所有的等待线程抢占资源。

2) Share(共享)

运行多个线程对资源共享,比如JUC并发工具CountDownLatch、Semaphore等都是运行多个线程访问资源。

AQS 模板方法运用并发基础之AQS(并发操作的定义)

AQS内置很多的操作方法,比如获取锁 tryAcquire()、释放锁 tryRelease()、超时获取tryAcquireNanos()、响应中断 acquireInterruptibly()等操作方法

在实际的运用过程中,我们可以直接继承AQS从而轻易的获取这些方法来实现我们的同步器。

当前JUC下的并发工具类都是基于AQS来实现自己的功能的,我们现在来鉴赏一下。

比如可重入锁ReentrantLock,我们进入源码查看,ReentrantLock内部类继承AQS:

我们ReentrantLock超时获取锁/释放锁也都是调用AQS超时获取锁/释放锁的方法:

当然其他对资源状态和队列的操作方法都是基于AQS实现的,对于JUC中其他的并发工具类也是如此,都是基于AQS实现。

补充知识CAS

CAS是Compare and Swap 的缩写,也就是比较和替换,是JUC最核心最基础的理论。原理是基于三个数据 主存值V、线程副本值A、需要修改为值B。当且仅当主存值V等于线程副本值A的时候,才能将数据修改为B。

CAS的优点

CAS是乐观锁,且一直自旋等待锁,所以性能很高。

CAS的缺点

ABA问题,如果我们先将值C修改为D,再修改为C,CAS会认为此数据没有修改。

缺点解决办法

1、加版本号

2、JAVA JUC atomic下提供AtomicStampedReference包装类

总结

AQS是位于java.util.concurrent.locks 包下的 AbstractQueuedSynchronizer类,是构建同步器和锁的基础框架。JAVA JUC并发包下的工具类都是基于AQS实现,其原理都是通过state状态来确定线程是否占用资源,未拿到锁的线程则放置在CLH虚拟双向队列末尾,后续通过AQS通知抢占资源。

本文链接地址:https://www.jiuchutong.com/zhishi/300110.html 转载请保留说明!

上一篇:【HTML | CSS】春节将至,为网页挂上精美的灯笼吧(附源码)程序员的浪漫(_ html)

下一篇:人工智能助力古彝文识别,推动传统文化传承(人工智能助力中国创新发展)

  • 离岸价的含义
  • 车辆购置税会计核算
  • 个税返还手续费奖励员工账务处理
  • 国债收益率如何定价
  • 专票小数点没打印齐能用吗
  • 增值税普通发票有什么用
  • 净利润为什么要减折旧
  • 公司代个人收承兑汇票
  • 汇算清缴所得税是什么意思
  • 直接转让土地使用权税费
  • 收到捐赠货物的会计分录怎么写
  • 个人所得税如何申报
  • 关税的增值税计算公式
  • 以前年度做的预算怎么查
  • 因产品不合格退回报废会计处理
  • 不收汇样品的会计分录
  • 不交社保的单位违法吗?
  • 个人股东从公司借款合法吗
  • 小规模季度超过30万,普票咋交税
  • 出口退税预审在申报系统怎么做
  • 装修改造空调尾板多少钱
  • 娱乐行业缴税
  • 企业所得税以前年度所得调整
  • 代购买东西流程
  • win10专业版版本号2009
  • 业务招待费是收入的
  • bios报警声是怎样的
  • 如何做好系统备案工作
  • 如何解决win7系统蓝牙接收模块影响电脑蓝屏
  • 工程审计需要什么条件
  • 企业购买预付卡送人分录
  • 劳务报酬怎么做帐
  • h5能不能自动播放
  • 已抵扣增值税进什么科目
  • 超过500万需要补税吗
  • 增值税报表填报说明
  • 股东分红税率是20%还是25%
  • mysqljoin查询
  • 使用uni-app开发网站
  • html5开发的app有哪些
  • 机器视觉 machine
  • 微信小程序上面有个音乐怎么关闭
  • vue3环境搭建
  • php中cookie的值存储在哪
  • php安装openssl扩展
  • 商业企业退货与退款区别
  • 税务三方协议怎么重签
  • 企业所得税的特别纳税调整
  • 小规模企业出售汽车如何交税
  • DEDECMSV5.6将软件下载次数直接生成静态
  • 公司滞纳金员工承担怎么做账
  • 收到承兑汇票在什么科目
  • 专利权的入账价值包括资本化支出吗
  • 生产自己的产品
  • 应付国库集中支付结余核算
  • 发放工资社保的账务处理
  • 劳务公司机械租赁费列入什么费用
  • 单位给食堂的补贴怎么算
  • 企业利润总额计算例题及答案
  • 总公司可以给子公司开票吗
  • 实收资本增加印花税税目怎么填
  • 没有报关单可以出口吗
  • 私营企业固定资产法律制度
  • 线上MYSQL同步报错故障处理方法总结(必看篇)
  • xp启动时间长
  • docker 开源项目
  • 疯狂冰淇淋罗德
  • perl遍历哈希
  • cocos2d开发app
  • 谈谈jQuery Ajax用法详解
  • Nodejs sublime text 3安装与配置
  • CalledFromWrongThreadException: Only the original thread that created a view
  • shell 正则表达式 *什么意思
  • nodejs如何使用
  • js鼠标点击图片就消失
  • jquery mobile 图片滑动
  • css图片渐变效果
  • typeto
  • HTTP之Range理解
  • 全国书法等级考试官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设