多线程安全——AQS

AQS(AbstractQueuedSynchronizer)是Java并发编程中的核心类,用于构建锁和同步器。它通过维护一个同步状态并管理线程的阻塞与唤醒,实现了独占和共享两种资源访问模式。在AQS中,线程通过CLH队列进行等待,当资源可用时,线程被唤醒。ReentrantLock、Semaphore和CountDownLatch等并发工具类都是基于AQS实现的。
摘要由CSDN通过智能技术生成

概念

AbstractQueuedSynchronizer抽象类(以下简称AQS)是整个java.util.concurrent包的核心。在JDK1.5时,Doug Lea引入了J.U.C包,该包中的大多数同步器都是基于AQS来构建的。AQS框架提供了一套通用的机制来管理同步状态(synchronization state)、阻塞/唤醒线程、管理等待队列如常用的 ReentrantLock/Semaphore/CountDownLatch都是依赖于它

AQS框架,分离了构建同步器时的一系列关注点,它的所有操作都围绕着资源——同步状态(synchronization state)来展开,并替用户解决了如下问题:

  • 资源是可以被同时访问?还是在同一时间只能被一个线程访问?(共享/独占功能)
  • 访问资源的线程如何进行并发管理?(等待队列)
  • 如果线程等不及资源了,如何从等待队列退出?(超时/中断)

AQS框架将剩下的一个问题留给用户:
什么是资源?如何定义资源是否可以被访问?

这其实是一种典型的模板方法设计模式:父类(AQS框架)定义好骨架和内部操作细节,具体规则(比如资源的获取/释放方式)由子类去实现。

资源访问模式

支持独占模式和共享模式

Exclusive 独占资源

Exclusive(独占,只有一个线程能执行,如 ReentrantLock)

Share 共享资源

Share(共享ÿ

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值