Java并发编程系列之CyclicBarrier的使用

在日常活动中,经常会遇到这样一种场景:我们会约定在某个地点集合,等所有的组员都集合后,然后我们才开始活动,等活动结束后,所有的组员再一次集合,报道后再各自回家。在我们的程序中,也会经常遇到这种场景,需要所有的子线程都结束之后,再汇聚所有的结果,然后根据结果在决定下一步的操作,这个时候,我们就需要使用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 
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值