ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

【Java面试】请谈谈AQS是怎么回事儿?

2022-07-12 11:01:54  阅读:174  来源: 互联网

标签:Java AQS 实现 Mic FIFO 回事儿 线程 竞态


Hi,大家好,我是Mic。

今年的市场环境是真的很难。很多工作一年的人,面试的难度相当于一个4年经验的人。

image-20220518212100187

越是这样,我们越应该强大自己,才能在逆境中获得更多的机会。

今天一个一年经验的粉丝,被问到“AQS的实现原理”,来找我求助。

下面看看高手对于这个问题的回答。

喜欢我作品的小伙伴,记得点赞收藏加关注。

高手:

AQS它是J.U.C这个包里面非常核心的一个抽象类,它为多线程访问共享资源提供了一个队列同步器。

在J.U.C这个包里面,很多组件都依赖AQS实现线程的同步和唤醒,比如Lock、Semaphore、CountDownLatch等等。

AQS内部由两个核心部分组成:

  • 一个volatile修饰的state变量,作为一个竞态条件
  • 用双向链表结构维护的FIFO线程等待队列

它的具体工作原理是,多个线程通过对这个state共享变量进行修改来实现竞态条件,

竞争失败的线程加入到FIFO队列并且阻塞,

抢占到竞态资源的线程释放之后,后续的线程按照FIFO顺序实现有序唤醒。

image-20220519130818819

AQS里面提供了两种资源共享方式,

一种是独占资源,同一个时刻只能有一个线程获得竞态资源。比如ReentrantLock就是使用这种方式实现排他锁

另一种是共享资源,同一个时刻,多个线程可以同时获得竞态资源。CountDownLatch或者Semaphore就是使用共享资源的方式,实现同时唤醒多个线程。

总结

在实际开发中,如果我们需要实现一些特殊的互斥场景,

直接使用ReentrantLock又有点麻烦,那就可以自己去集成AQS,自定义多线程竞争的实现逻辑。

这个问题主要考察求职责对Java基础的理解。

file

版权声明:本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 Mic带你学架构
如果本篇文章对您有帮助,还请帮忙点个关注和赞,您的坚持是我不断创作的动力。欢迎关注「跟着Mic学架构」公众号公众号获取更多技术干货!

标签:Java,AQS,实现,Mic,FIFO,回事儿,线程,竞态
来源: https://www.cnblogs.com/mic112/p/16469268.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有