【多线程】CountDownLatch应用

本文通过比喻介绍CountDownLatch的使用,将其比作一场有5名选手的赛跑,详细阐述了在并发环境中,如何利用CountDownLatch确保所有线程在特定事件发生前等待,以及在所有任务完成后的继续执行。
摘要由CSDN通过智能技术生成

比喻

这个程序就像是5个选手在赛跑
1.5个选手都需要在跑道上准备
2.裁判需要在选手准备完毕后开枪喊开始
3.等5个选手都跑到终点 比赛结束

package concurrency;

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.Executor;
import java.util.concurrent.Executors;

public class CountDownLatchExample {

    /**
     * @param executor
     * @param concurrency
     * @param action
     * @return
     * @throws InterruptedException
     */
    public static long time(Executor executor, int concurrency,
                            final Runnable action) throws InterruptedException {
        final CountDownLatch ready = new CountDownLatch(concurrency);
        final CountDownLatch start = new CountDownLatch(1);
        final CountDownLatch done = new CountDownLatch(concurrency);
        for (int i = 0; i < concurrency; i++) {
            executor.execute(new Runnable() {
                public void run() {
                    ready.countDown(); // 告诉定时器 已准备完毕
                    System.out.println(Thread.currentThread().getName() + ": 准备完毕" );
                    try {
                        start.await(); // 等待其它线程都准备完毕
                        action.run();
                    } catch (InterruptedException e) {
                        Thread.currentThread().interrupt();
                    } finally {
                        done.countDown(); // 本线程任务已完成
                        System.out.println(Thread.currentThread().getName() + ": 跑到终点" );
                    }
                }
            });
        }
        ready.await(); // 祝线程等待所有工作线程都准备完毕
        
        long startNanos = System.nanoTime();
        System.out.println(Thread.currentThread().getName() + ": 裁判喊开始" );
        start.countDown(); // 开始

        done.await(); // 等待所有线程结束
        return System.nanoTime() - startNanos;
    }

    public static void main(String[] args) throws Exception{
        int concurrency = 5;
        Executor executor = Executors.newFixedThreadPool(concurrency);
        Runnable action = new Runnable() {
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName() + ": 赛跑中" );
            }
        };
        time(executor, concurrency, action);
    }
}

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值