使用 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 实现多线程同步,如何保证输出信息按创建顺序排列?的详细内容,更多请关注其它相关文章!