work hard work smart

专注于Java后端开发。 不断总结,举一反三。
随笔 - 1158, 文章 - 0, 评论 - 153, 阅读 - 186万
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

CountDownLatch

Posted on   work hard work smart  阅读(40)  评论(0编辑  收藏  举报

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

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

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

下面列出具体代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
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
1
2
3

  

应用场景:

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

 

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

 

相关博文:
阅读排行:
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· DeepSeek在M芯片Mac上本地化部署
历史上的今天:
2020-04-12 java子线程中获取父线程的threadLocal中的值
2020-04-12 String源码解析
点击右上角即可分享
微信分享提示