CountDownLatch倒计数器并发工具

CountDownLatch是一个并发工具,常用于多线程并行执行的场景。通过设置初始计数值,当所有线程完成任务后计数器减到0,主线程才能继续执行。注意,计数器设置需等于或小于线程数量,否则可能导致并行效果不佳或主线程阻塞。
摘要由CSDN通过智能技术生成

CountDownLatch:用于多线程并行执行
例:

@Slf4j
public class CountDownLatchDemo {

    private static volatile int index = 0;

    public static void main(String[] args) throws InterruptedException {
        //创建倒计数器,指定计数数量为3
        CountDownLatch countDownLatch = new CountDownLatch(3);
        ThreadPoolManager.ThreadPool threadPool = ThreadPoolManager.getThreadPool();
        for (int i = 1; i < 4; i++) {
            int s=++index;
            threadPool.execute(() -> {
                log.info(s + " runing " + System.currentTimeMillis());
                try {
                    Thread.sleep(1000);
                    log.info(s + " run end " + System.currentTimeMillis());
                } catch (InterruptedException e) {
                    log.error(e.getMessage(), e);
                } finally {
                    //通知CountDownLatch有一个线程已经准备完毕,倒计数器可以减一了
                    countDownLatch.countDown();
                }
            });
        }
        //要求主线程需等所有线程准备好后,并行执行完毕后才能继续执行
        countDownLatch.await();
        //关闭线程池
        threadPool.shutdown();
        log.debug("main Thread end");
    }
}

ThreadPoolManager.ThreadPool为自写的一个线程池工具,代码详情
输出:

1 runing 1564386456075
2 runing 1564386456076
3 runing 1564386456076
2 run end 1564386457080
1 run end 1564386457080
3 run end 1564386457080
main Thread end

各线程执行顺序可能与输出不一致,但是主线程必须在CountDownLatch倒计数器执行为0时才会继续执行。
注意:

  • CountDownLatch指定计数数量如小于线程数,那么超出的线程将可能不能达到并行的要求;
  • CountDownLatch指定的计数数量大于线程数,那主线程将无法执行完毕。

更多文章:
CSDN博客
简书博客
公众号:代码小搬运
代码小搬运.jpg

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值