位置: 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)

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

  • 贷款利息不能抵扣进项税
  • 个体工商户在哪注销营业执照
  • 收到赠品入库需要用什么记录
  • 财政拨款税收政策
  • 公允价值变动损益属于什么科目
  • 申请发票增额有没有什么条件
  • 土地股权转让需交什么税
  • 购进客房用品取得增值税专用发票注明税额9120
  • 4s店维修委托书的主要内容
  • 拆迁房视同销售成本可以抵减吗?
  • 用于文化活动费用的科目
  • 碎石需要技术吗
  • 应交印花税会计分录
  • 小规模纳税人可以自己开专票吗
  • 水泥厂水泥增值税率是多少?
  • 2020水利基金
  • 金税盘清卡晚了一天会怎么样
  • 买标书怎么做分录
  • 托儿所幼儿园卫生保健工作规范2022
  • 甲公司采用租赁方式租入一台大型设备
  • 轮胎计入什么会计科目
  • 总分类账户和明细分类账户平行登记的内容可以概括为
  • 资金占用费如何开票
  • 申请办理银行承兑流程
  • 商业汇票的目的
  • 年末计提银行借款利息
  • 下载的压缩文件打不开
  • 年度企业所得税汇算清缴会计分录怎么做
  • 会计交接的时候是不是有报税单
  • 矿业财务好做吗
  • 境外服务费代扣代缴所得税
  • 社保挂靠公司收费标准是怎样的
  • 城建税10%用于教育哪方面
  • rgb to hex
  • uni-app原理
  • 公司交社保国家承担吗
  • 事业单位收到的罚款收入应纳入
  • 红字发票信息表填好后再怎么操作
  • 票据带息和不带息
  • 帝国cms使用手册
  • 单位出租厂房需交税吗
  • 增值税增量留抵退税计算
  • 临时工工资账务处理该怎么进行
  • 现金流量表中支付的税费怎么填
  • SQL Server 2005 模板参数使用说明
  • 固定资产指的是几年度
  • 个税汇算清缴什么意思?
  • 计提坏账准备如何做会计分录
  • 在建工程科目核算只针对固定资产吗
  • 企业没有工会的需要计提嘛
  • 房地产毛利额纳税调整
  • 销售货物的运费的税率怎么算
  • 长期股权投资会计实训心得
  • 应付账款的逾期利息计入什么科目
  • 从基本存款账户划款3万元 向开户银行转帐
  • 补偿款怎么写才能有效
  • mysql死锁的例子
  • centos下安装jdk
  • 数据库mysql索引
  • ubuntu20.04升级
  • ubuntuone
  • Mac显示桌面快捷键
  • git 进阶
  • PACKAGER.EXE - PACKAGER是什么进程 有什么用
  • win8无法打开ie
  • JavaScript的函数库
  • JavaScript中对象方法的创建
  • adt Failed to create the Java Virtual Machine.
  • perl的$_
  • unity learn premium
  • jquery炫酷效果
  • 怎么设置网页就用指定浏览器
  • react jss
  • 滚动的纸箱
  • jquery中的基本选择器有哪些
  • jquery常用的事件绑定函数有哪些
  • 成都税务企业号公众号
  • 税务投诉撤销申诉
  • 北京税务查验中心官网
  • 中国有没有豁免权
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设