谈谈你对CountDownLatch的理解

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值