绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
关于下面CountDownLatch代码段的疑问
2019-08-21 10:27:58
public class CountDownLatchExample1 {

    private static int threadCount = 10;

    public static void main(String[] args) throws InterruptedException {
        ExecutorService es = Executors.newCachedThreadPool();
        CountDownLatch countDownLatch = new CountDownLatch(threadCount);
        for (int i = 0; i < threadCount; i++) {
            final int count = i;
            es.execute(() -> {
                try {
                    test(count);
                } catch (Exception e) {
                    log.error("Exception,{}", e);
                } finally {
                    countDownLatch.countDown();
                }
            });
        }
        countDownLatch.await(1, TimeUnit.MILLISECONDS);
        log.info("======");
        es.shutdown();
    }

    public static void test(int i) throws InterruptedException {
        Thread.sleep(1000);//此方法延迟1秒再执行
        log.info("test {}", i);
    }

}

由于在方法里面加了一秒延迟 所以先打印出======,那为什么其他10条log信息同一秒出现了?

分享好友

分享这个小栈给你的朋友们,一起进步吧。

应用开发
创建时间:2020-06-17 15:31:04
应用软件开发是指使用程序语言C#、java、 c++、vb等语言编写,主要是用于商业、生活应用的软件的开发。
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

技术专家

查看更多
  • 栈栈
    专家
戳我,来吐槽~