谈谈你对CountDownLatch的理解

本文深入探讨了Java并发工具类CountDownLatch的使用场景与机制,包括多线程数据汇总、大数据包分块传输及服务启动时组件加载的同步控制。CountDownLatch通过计数器实现线程间的等待与唤醒,确保所有相关线程完成任务后再继续执行。

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

CountDownLatch是java.util.concurrent包中一个工具类。它能够使一个或者多个线程等待另外一些线程完成各自的工作之后,再继续执行

使用CountDownLatch的一些情景:

①需要去解析一个Excel的数据,为了更快的解析,每个sheet都使用一个线程进行解析,但是最后汇总数据的工作需要等待每个sheet的解析工作完成之后才能进行

②开启多个线程分块传输一个大数据包,每个线程只传输固定的一截,最后由另外一个线程拼接所有的分块

③启动一个服务时,主线程需要等待多个组件加载完毕,之后再继续执行。

CountDownLatch类实际上是使用计数器的方式去控制的计数器初始值为线程的数量。当每一个线程完成自己任务后,计数器的值就会减一。当计数器的值为0时,表示所有的线程都已经完成了任务,然后在CountDownLatch上等待的线程就可以恢复执行任务。

CountDownLatch的不足

CountDownLatch是一次性的,计数器的值只能在构造方法中初始化一次,之后没有任何机制再次对其设置值,当CountDownLatch使用完毕后,它不能再次被使用

public class CountDownLatchDemo {

public static void main(String[] args) throws InterruptedException{

CountDownLatch countDownLatch = new CountDownLatch(2){

@Override

public void await() throws InterruptedException {

super.await();

System.out.println(Thread.currentThread().getName() +  " count down is ok");

}

};

Thread thread1 = new Thread(new Runnable() {

@Override

public void run() {

//do something

try {

Thread.sleep(1000);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println(Thread.currentThread().getName() + " is done");

countDownLatch.countDown();

}

}, "thread1");

 

Thread thread2 = new Thread(new Runnable() {

@Override

public void run() {

//do something

try {

Thread.sleep(2000);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println(Thread.currentThread().getName() + " is done");

countDownLatch.countDown();

}

}, "thread2");

 

thread1.start();

thread2.start();

countDownLatch.await();

}

}

输出结果

thread1 is done

thread2 is done

main count down is ok

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值