1.简介
通俗点讲就是一组线程相互等待,直到临界点。具体可查官方文档
注意:CountDownLatch是一组线程或一个线程等待另一组线程
2.小栗子
public class CyclicBarrierDemo {
private static final int CYCLIC_BARRIER_COUNT = 2;
private static final int THREAD_COUNT = 4;
public static void main(String[] args) {
CyclicBarrier cyclicBarrier = new CyclicBarrier(CYCLIC_BARRIER_COUNT, ()->{
System.out.println("达到临界点");
});
ExecutorService executorService = Executors.newFixedThreadPool(THREAD_COUNT);
for (int index = 0; index < THREAD_COUNT; index ++) {
executorService.execute(()->{
try {
System.out.println("ThreadId:" + Thread.currentThread().getId());
Thread.sleep(2000);
int await = cyclicBarrier.await();
System.out.println("await:" + await);
System.out.println("ThreadId:" + Thread.currentThread().getId());
} catch (Exception e) {
e.printStackTrace();
}
});
}
executorService.shutdown();
}
}
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。