高并发之 CountDownLatch

CountDownLatch是一个同步工具,用于让一个或多个线程等待其他线程完成操作。它通过初始化一个计数器,调用await()使线程等待,countDown()使计数器减一。主要应用于主线程等待子线程执行完毕和发令枪场景。注意线程池设置以避免线程不同时运行。其内部基于AQS的state管理计数。
摘要由CSDN通过智能技术生成

概念

CountDownLatch是一个通用的同步工具,CountDownLatch允许一个或多个线程在其他线程执行操作完成前等待。

用法

CountDownLatch需要初始化一个计数器,调用await()方法使线程阻塞,调用countDown()方法让计数器减一,当计数器减为零时,所有等待的线程释放,并且后续await()的线程立即执行。

场景

使用CountDownLatch主要有两个场景

  1. 主线程阻塞直到子线程全部执行完毕。比如,我和女朋友一起去吃麻辣烫,厨师需要等我和女朋友全部点完配菜之后才可以开始制作,而我和女朋友选菜的过程是可以同时进行的。
public class CDLForSpicyHotPot {
   

    //设置计数器
    private static CountDownLatch latch = new CountDownLatch(2);

    public static void main(String[] args) throws InterruptedException {
   
        ExecutorService executor = Executors.newFixedThreadPool(2);

        //我和女朋友开始选配菜
        ArrayList<String> users = Lists.newArrayList("Me", "GF");
        for (String user : users) {
   
            executor.submit(() -> {
   
                chooseSomething(user);
                //选好了
                latch.countDown();
            });
        }

        //厨师等待中
        latch.await();
        System.out.println(System.currentTimeMillis() + " : The Cooker begin to cook");

        if(!executor.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值