在日常活动中,经常会遇到这样一种场景:我们会约定在某个地点集合,等所有的组员都集合后,然后我们才开始活动,等活动结束后,所有的组员再一次集合,报道后再各自回家。在我们的程序中,也会经常遇到这种场景,需要所有的子线程都结束之后,再汇聚所有的结果,然后根据结果在决定下一步的操作,这个时候,我们就需要使用CyclicBarrier,进行线程的同步。下面先看一个简单的示例,代码如下:
public class CyclicBarrierDemo {
public static void main(String[] args) throws InterruptedException {
// 新建一个CyclicBarrier,同时指定到达集合点的个数和到达集合点之后要做什么事
final CyclicBarrier barrier = new CyclicBarrier(5, new Runnable() {
@Override
public void run() {
System.out.println("所有人都到了,开始活动……");
}
});
/*
* 新建5个线程,此处线程数必须和CyclicBarrier中到达集合点的个数一致,否则会出问题
* 如果此处设置成4的话,就会一直等待,直到第5个线程到来
*/
ExecutorService service = Executors.newFixedThreadPool(5);
// 提交5个任务
for(int i=0; i<5; i++){
Thread.sleep(1000);
service.execute(new Runnable() {
@Override
public void run() {
try {
System.out.println(Thread.currentThread().getName()+"到达园博园了!");
Thread.sleep(2000);
// 在此等待,直到所有的线程都到这里,才往下走
barrier.await();
} catch (InterruptedException e) {
e.printStackTrace();
} catch (BrokenBarrierException e) {
e.printStackTrace();
}
}
});
}
// 释放线程池资源
service.shutdown();
}
}
测试结果如下:
pool-1-thread-1到达园博园了!
pool-1-thread-2到达园博园了!
pool-1-thread-3到达园博园了!
pool-1-thread-4到达园博园了!
pool-1-thread-5到达园博园了!
所有人都到了,开始活动……
从测试结果可以看出,线程之间是互相等待,直到所有的线程都到达集合点之后,才会往下走。
---------------------
作者:牛奋lch
来源:CSDN
原文:https://blog.csdn.net/liuchuanhong1/article/details/53539730
版权声明:本文为博主原创文章,转载请附上博文链接!