Java并发编程之CountDownLatch解析
Java的CountDownLatch
ReentrantLock为独占锁,也即排他锁,同一时刻只能有一个线程持有锁。现在来看几种共享锁。
CountDownLatch
public CountDownLatch(int count) {
if (count < 0) throw new IllegalArgumentException("count < 0");
this.sync = new Sync(count);
}
private final Sync sync;
private static final class Sync extends AbstractQueuedSynchronizer {
private static final long serialVersionUID = 4982264981922014374L;
Sync(int count) {
//设置资源总数
setState(count);
}
int getCount() {
return getState();
}
protected int tryAcquireShared(int acquires) {
//资源
return (getState() == 0) ? 1 : -1;
}
protected boolean tryReleaseShared(int releases) {
// Decrement count; signal when transition to zero
for (;;) {
//1、获取当前资源数
int c = getState();
if (c == 0)
return false;
//2、释放一个资源
int nextc = c-1;
//3、CAS更新资源数
if (compareAndSetState(c, nextc))
return nextc == 0;
}
}
}生成CountDownLatch时需要传入资源总数,代表所有线程总共享有这么多资源。
Sync为一个实现了AQS的内部类,代理CountDownLatch的获取和释放操作。
public void await() throws InterruptedException {
sync.acquireSharedInterruptibly(1);
}
public void countDown() {
sync.releaseShared(1);
}线程调用countDown时,最终调用Sync中的tryReleaseShared,将总资源减1。
调用await时,最终调用Sync中tryAcquireShared,看资源是否全部释放完。
需要所有线程等待某个条件完成后,才执行某个动作时,可以使用CountDownLatch。
到此这篇关于Java并发编程之CountDownLatch解析的文章就介绍到这了,更多相关Java的CountDownLatch内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
详解springboot启动时是如何加载配置文件application.yml文件
这篇文章主要介绍了详解springboot启动时是如何加载配置文件application.yml文件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-06-06
SpringBoot中实现大文件分片下载和断点续传功能的完整指南
在Spring Boot中实现大文件分片下载和断点续传功能,需结合HTTP Range协议和文件流处理技术,本文将展示完整的实现方法,有需要的小伙伴可以参考一下2025-09-09
原因分析IDEA导入Spring-kafka项目Gradle编译失败
这篇文章主要为大家介绍分析了IDEA导入Spring-kafka项目Gradle中编译失败原因及解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步2022-02-02


最新评论