你的位置:首页 > 信息动态 > 新闻中心
信息动态
联系我们

Java的并发 CountDownLatch的使用方法

2021/12/19 17:51:29

Java的并发 CountDownLatch的使用方法标题

CountDownLatch是一个同步辅助类,犹如倒计时计数器,创建对象时通过构造方法设置初始值,调用CountDownLatch对象的await()方法则处于等待状态,调用countDown()方法就将计数器减1,当计数到达0时,则所有等待者或单个等待者开始执行

import java.util.concurrent.*;

public class CountDownLacthTest {
    public static void main(String[] args) {
        final CountDownLatch order =new CountDownLatch(1);//指挥官,设置为1,下达命令之后变为0
        final CountDownLatch wait =new CountDownLatch(3);//三个任务等待完成,每次执行之后减为1,最后变为0 ,指挥官停止等待
        ExecutorService executor = Executors.newCachedThreadPool();//创建一个线程池
        for (int i = 0; i < 3; i++) {
            Runnable runnable = new Runnable() {
                @Override
                public void run() {
                    try {
                        System.out.println("线程"+Thread.currentThread().getName()+"正准备接受命令");
                        order.await();//等待指挥官下达命令
                        System.out.println("线程"+Thread.currentThread().getName()+"已接受命令");
                        TimeUnit.SECONDS.sleep(10);
                        System.out.println("线程"+Thread.currentThread().getName()+"回应处理的结果");
                        wait.countDown();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            };
            executor.execute(runnable);
        }
        try {
            TimeUnit.SECONDS.sleep(10);
            System.out.println("线程"+Thread.currentThread().getName()+"即将发布命令");
            order.countDown();
            System.out.println("线程"+Thread.currentThread().getName()+"已发布命令,等待结果");
            wait.await();
            System.out.println("线程"+Thread.currentThread().getName()+"已收到所有的响应结果");
        } catch (Exception e) {
            e.printStackTrace();
        }
        executor.shutdown();
    }
}

输出结果

线程pool-1-thread-2正准备接受命令
线程pool-1-thread-1正准备接受命令
线程pool-1-thread-3正准备接受命令
线程main即将发布命令
线程main已发布命令,等待结果
线程pool-1-thread-3已接受命令
线程pool-1-thread-1已接受命令
线程pool-1-thread-2已接受命令
线程pool-1-thread-2回应处理的结果
线程pool-1-thread-3回应处理的结果
线程pool-1-thread-1回应处理的结果
线程main已收到所有的响应结果

Process finished with exit code 0