有时候需要对某个业务方法进行多线程并发测试,可以考虑如下代码段:
@Test
public void testParse() {
final int THREAD_COUNT = 10;
ExecutorService executorService = Executors.newFixedThreadPool(THREAD_COUNT);
CountDownLatch latch = new CountDownLatch(THREAD_COUNT);
CyclicBarrier cyclicBarrier = new CyclicBarrier(THREAD_COUNT);
for (int i = 0; i < THREAD_COUNT; i++) {
executorService.execute(() -> {
try {
cyclicBarrier.await();
// 业务代码
} catch (Throwable e) {
e.printStackTrace();
} finally {
latch.countDown();
}
});
}
try {
latch.await();
executorService.shutdownNow();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/17276.html