[JUC] AQS共享模式详解

本文通过分析CountDownLatch的实现原理,详细介绍了其如何利用AQS的共享模式进行线程间的同步操作。通过具体场景说明,展示了CountDownLatch在多线程环境下如何控制线程的等待与唤醒机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[JUC] AQS独占模式详解中我们已经结合ReentrantLock分析了AQS独占模式的实现,本文将结合CountDownLatch分析共享模式的实现。

场景说明

如下图所示,有一个初始值为3的CountDownLatch,线程t1和t2在时间线1调用await等待latch的值变为0,线程t3在时间线2调用countDown()latch值减1,线程t4在时间线3调用countDown()latch值减1,线程t5在时间线4调用countDown()latch值减1,此时latch值变为0,线程t1和t2在时间线4后同时获取到锁
场景描述

CountDownLatch是如何使用AQS

首先我们看构造一个CountDownLatch做了什么事情

CountDownLatch latch = new CountDownLatch(3);

CountDownLatch构造方法实现如下

    public CountDownLatch(int count) {
        if (count < 0) throw new IllegalArgumentException("count < 0");
        // 创建一个内部的Sync对象,并传入count
        this.sync = new Sync(count);
    }

	private static final class Sync extends AbstractQueuedSynchronizer {
        ...
        Sync(int count) {
        	// 将AQS的同步状态state设为count
            setState(count);
        }
		...
    }

可见CountDownLatch的构造方法就是将传入的count设置到AQS的同步状态state上去。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值