CountDownLatch-等待一个线程池执行完所有线程

  • 创建一个线程池 threadPoolExecutor 线程数量为threadCount,
  • 执行methodA()方法,threadCount次
  • 等待线程池的线程全部执行完,即latch为0
  • shutdown()线程池
复制代码
    @Test
    public void test(int threadCount) {
        ExecutorService threadPoolExecutor = new ThreadPoolExecutor(
          threadCount/2,
          threadCount,
1L, TimeUnit.SECONDS, new LinkedBlockingQueue<>(threadCount), Executors.defaultThreadFactory(), new ThreadPoolExecutor.AbortPolicy()); CountDownLatch latch = new CountDownLatch(threadCount); //循环执行methodA()方法 for (int count = threadCount; count > 0; count--) { threadPoolExecutor.submit(() -> { try { methodA( ); } catch (Exception e) { log.error(e.getMessage(), e); } finally { latch.countDown(); } }); } //阻塞当前主线程,直到latch等于0 try { //阻塞当前线程,直到计数器的值为0 latch.await(); } catch (InterruptedException e) { e.printStackTrace(); } //关闭线程池 threadPoolExecutor.shutdown(); }
复制代码

 

posted @   isalo  阅读(246)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示