work hard work smart

专注于Java后端开发。 不断总结,举一反三。
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

CountDownLatch

Posted on 2022-04-12 09:55  work hard work smart  阅读(34)  评论(0编辑  收藏  举报

CountDownLatch,它是一种计数器的方式保证线程同步;它不去控制多个线程之间的前后关系,只保证某一线程能够在这些子线程执行完之后再执行。

CountDownLatch类似于计数器的方式,用于等待一个或多个线程执行完操作开始自身代码的执行。

其构造函数接收一个int类型的整数作为计数器而使用,例如如果想等待N个线程执行完毕就传入N,当每调用一次countDown函数,表示某一个线程执行完毕。实际上,这个N并不是与线程绑定,也就是说并不是一定和线程的数量一致,只需要countDown函数执行N次,当前等待的线程就会开始执行。

下面列出具体代码

public class CountDownLatchTest {


    static CountDownLatch countDownLatch = new CountDownLatch(2);
    public static void main(String[] args) {

        new Thread(new Runnable() {
            @Override
            public void run() {
                SleepUtils.second(2);
                System.out.println("1");
                countDownLatch.countDown();
            }
        }).start();
        new Thread(new Runnable() {
            @Override
            public void run() {
                SleepUtils.second(4);
                System.out.println("2");
                countDownLatch.countDown();
            }
        }).start();
        try {
            // 主线程开始等待
            countDownLatch.await();

        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("3");
    }
}

  

输出结果:

1
2
3

  

应用场景:

当遇到一个比较耗时的计算量较大的任务时,我们则可以考虑使用多线程来操作,将一个大任务拆分成多个小任务(一个任务相当于一个线程),当每个小任务执行完毕返回结果后,再由某一主线程对结果进行统计。

 

参考:https://blog.csdn.net/qq_27828675/article/details/114068266