八、并发工具类之CyclicBarrier

CyclicBarrier

CyclicBarrier和CountDownLatch功能相似。CyclicBarrier是所有参与线程互相等待对方执行到某点,再一起执行后面程序。

与CountDownLatch一样,CyclicBarrier的构造函数也需要一个int类型的参数 parties,表示参与者数量。每一个线程调用cyclicBarrier对象的await方法就会进入等待。直到参与线程数量到达parties时,唤醒所有线程。

场景:所有参与者进入等待,在执行


 final CyclicBarrier cyclicBarrier = new CyclicBarrier(5);
        for(int i=0 ;i<5;i++){
            final int c=i;
            new Thread(){
                @Override
                public void run() {
                    try {
                        System.out.println(String.format("参与者%d等待",c));
                        cyclicBarrier.await();
                        System.out.println(String.format("参与者%d执行",c));
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
            }.start();
 }

执行结果

参与者3等待
参与者1等待
参与者2等待
参与者4等待
参与者0等待
参与者3执行
参与者0执行
参与者1执行
参与者2执行
参与者4执行

CyclicBarrier和CountDownLatch的区别

  1. CyclicBarrier内部用条件变量Condition实现,会产生上下文切换。CountDownLatch使用乐观锁实现。
  2. CyclicBarrier当parties=0时,在唤醒所有线程同时,还会重置parties。 CountDownLatch不能重置回滚。

CyclicBarrier使用场景

  1. 迭代算法并发化。迭代中,由多个工作线程完成工作。使用await等待所有工作线程完成工作,再将结果作为下一轮迭代的输入。

  2. 模拟高并发。保证线程同时开始其操作来模拟高并发测试。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值