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带你学架构
如果本篇文章对您有帮忙,还请帮忙点个关注和赞,您的保持是我一直创作的能源。欢送关注同名微信公众号获取更多技术干货!