zoukankan      html  css  js  c++  java
  • 使用CountDownLatch等待多线程

    前言 
    CountDownLatch 允许一个或多个线程等待其他线程完成操作。 
    应用场景 
    假如有一个列表的大量数据等待处理,最后全部处理完毕后返回处理结果。普通做法就是从头遍历,一个个顺序执行,这样单线程处理效率不高,我们希望使用多线程的方式处理,同时在主线程等待所有子线程处理完成。

    CountDownLatch的构造函数接收一个int类型的参数作为计数器,如果你想等待N个点完成,这里就传入N。 
    当我们调用一次CountDownLatch的countDown方法时,N就会减1,CountDownLatch的await会阻塞当前线程,直到N变成零。由于countDown方法可以用在任何地方,所以这里说的N个点,可以是N个线程,也可以是1个线程里的N个执行步骤。用在多个线程时,你只需要把这个CountDownLatch的引用传递到线程里。

    示例代码

    public static void main(String args[]){
            //初始化计数
            AtomicInteger count = new AtomicInteger(0);
            //创建10个线程
            ExecutorService executorService = Executors.newFixedThreadPool(10);
            //设置CountDownLatch为10
            CountDownLatch countDownLatch = new CountDownLatch(10);
            for(int i=0;i<10;i++){
                executorService.execute(() -> {
                    //每个线程累加10000次
                    for(int j=0;j<10000;j++){
                        count.addAndGet(1);
                    }
                    //线程最后执行countDown
                    countDownLatch.countDown();
                });
            }
            try{
                //调用await方法等待
                countDownLatch.await();
            }catch(Exception e){
                e.printStackTrace();
            }
            System.out.println(count.toString());
        }



    最后的执行结果就是10*10000=100000,可见所有线程都处理完了。

    扩展 
    CountDownLatch的await方法还支持超时时间的设置,当等待超时时间子线程还没执行完将不再等待继续执行主线程。

    public boolean await(long timeout, TimeUnit unit)
    1
    熟练使用多线程处理,可以再处理大量重复性工作时发挥多线程处理的效率优势。

  • 相关阅读:
    一个有关FWT&FMT的东西
    【XSY2762】插线板 分块
    【XSY1905】【XSY2761】新访问计划 二分 树型DP
    【XSY2760】nonintersect 计算几何
    【XSY2787】Mythological VII 贪心
    【XSY2786】Mythological VI 数学
    【XSY2785】模型
    【BZOJ4126】【BZOJ3516】【BZOJ3157】国王奇遇记 线性插值
    【XSY2751】Mythological IV 线性插值
    【XSY2750】Mythological V 2-sat
  • 原文地址:https://www.cnblogs.com/wanchen-chen/p/12934118.html
Copyright © 2011-2022 走看看