使用 CountDownLatch 实现多线程同步,如何保证输出信息按创建顺序排列?

使用 countdownlatch 实现多线程同步,如何保证输出信息按创建顺序排列?

关于 countdownlatch 代码段的疑惑

代码中使用了 countdownlatch 实现多线程任务的同步。但是,在 test 方法中,每个线程都执行了 thread.sleep(1000),即延迟 1 秒后才输出信息。

问题:

这段代码的目的似乎是等待所有线程执行完 test 方法后再继续执行。但由于线程的延迟,输出结果可能不会按照创建顺序排列。如何确保输出按创建顺序排列?

答案:

给出的代码段使用了线程池,这意味着所有 10 个线程几乎同时执行,导致输出信息乱序。

想要按照创建顺序输出信息,需要在一个线程内按顺序执行所有任务。可以使用循环或其他同步机制来实现这一点。

例如,可以在 main 方法中创建一个循环,依次创建和等待每个线程:

CountDownLatch countDownLatch = new CountDownLatch(threadCount);

for (int i = 0; i  {
        try {
            test(count);
        } catch (Exception e) {
            log.error("Exception,{}", e);
        } finally {
            countDownLatch.countDown();
        }
    }).start();
}

countDownLatch.await(1, TimeUnit.MILLISECONDS);

通过在循环中创建和等待每个线程,可以确保按创建顺序执行任务,从而保证输出的顺序性。

以上就是使用 CountDownLatch 实现多线程同步,如何保证输出信息按创建顺序排列?的详细内容,更多请关注www.sxiaw.com其它相关文章!