【Java面试】请谈谈AQS是怎么回事儿?
2023-03-31 11:01:14 时间
Hi,大家好,我是Mic。
今年的市场环境是真的很难。很多工作一年的人,面试的难度相当于一个4年经验的人。
越是这样,我们越应该强大自己,才能在逆境中获得更多的机会。
今天一个一年经验的粉丝,被问到“AQS的实现原理”,来找我求助。
下面看看高手对于这个问题的回答。
喜欢我作品的小伙伴,记得点赞收藏加关注。
高手:
AQS它是J.U.C这个包里面非常核心的一个抽象类,它为多线程访问共享资源提供了一个队列同步器。
在J.U.C这个包里面,很多组件都依赖AQS实现线程的同步和唤醒,比如Lock、Semaphore、CountDownLatch等等。
AQS内部由两个核心部分组成:
- 一个volatile修饰的state变量,作为一个竞态条件
- 用双向链表结构维护的FIFO线程等待队列
它的具体工作原理是,多个线程通过对这个state共享变量进行修改来实现竞态条件,
竞争失败的线程加入到FIFO队列并且阻塞,
抢占到竞态资源的线程释放之后,后续的线程按照FIFO顺序实现有序唤醒。
AQS里面提供了两种资源共享方式,
一种是独占资源,同一个时刻只能有一个线程获得竞态资源。比如ReentrantLock就是使用这种方式实现排他锁
另一种是共享资源,同一个时刻,多个线程可以同时获得竞态资源。CountDownLatch或者Semaphore就是使用共享资源的方式,实现同时唤醒多个线程。
总结
在实际开发中,如果我们需要实现一些特殊的互斥场景,
直接使用ReentrantLock又有点麻烦,那就可以自己去集成AQS,自定义多线程竞争的实现逻辑。
这个问题主要考察求职责对Java基础的理解。
版权声明:本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自
Mic带你学架构
!
如果本篇文章对您有帮助,还请帮忙点个关注和赞,您的坚持是我不断创作的动力。欢迎关注「跟着Mic学架构」公众号公众号获取更多技术干货!
相关文章
- Springboot注册Servlet几种方式你都知道?内部实现原理解析
- 优化 Golang 分布式行情推送的性能瓶颈
- 面向Java开发人员的十种测试框架库
- 关于Java代码优化的N条建议!
- GitHub 上最受欢迎的 5 大 Java 项目
- 为什么我不推荐你使用RabbitMQ的消息转换功能
- 单例模式实现的7种套路,你知道几个?
- Java提高篇——对象克隆(复制)
- Java多线程的应用场景和应用目的举例
- Java多线程实现的三种方式
- C ++委员会决定在C ++ 20中弃用原始指针
- 这一次彻底搞懂JDK动态代理
- TensorFlow学习之神经网络的构建
- Java 10来了,来看看它一同发布的全新JIT编译器
- 初识Python:Hello World和字符串操作
- 从Java到区块链:如何成为一名区块链开发者?
- 干货:排名前16的Java工具类!
- 编程语言中的一些邪恶咒语,千万不要用
- 使用pelican和Github pages来搭建博客
- 技术上难分高下,为什么市场选择了Java?