Java多线程之CyclicBarrier基础篇

一、关于CyclicBarrier的举例
  • 比如我们打篮球前首先得把人交齐,人到齐了才可以开始玩,玩的过程中每个人有不同的角色,这里的人相当于不同的线程,角色所担当的任务相当于线程执行的任务示例代码如下
public class MyCyclicBarrier {
    private static CyclicBarrier barrier = new CyclicBarrier(4,()-> 
    // 相当于裁判发令可以打球了
System.out.println("人都来齐了可以开始打球了"));
    public static void main(String[] args) {
        new Thread(()->{
            try {
                /*等大家都到齐,人一旦到齐就可以开打球了*/
                Thread.sleep(1000);
                barrier.await();
                System.out.println("我是控球后卫我正在控球");
            } catch (InterruptedException e) {
                e.printStackTrace();
            } catch (BrokenBarrierException e) {
                e.printStackTrace();
            }
        }).start();
        new Thread(()->{
            try {
                /*等大家都到齐,人一旦到齐就可以开打球了*/
                barrier.await();
                Thread.sleep(1000);
                System.out.println("我是得分后卫我正在投篮");
            } catch (InterruptedException e) {
                e.printStackTrace();
            } catch (BrokenBarrierException e) {
                e.printStackTrace();
            }
        }).start();
        new Thread(()->{
            try {
                /*等大家都到齐,人一旦到齐就可以开打球了*/
                barrier.await();
                Thread.sleep(1000);
                System.out.println("我是大前锋我正配个各位");
            } catch (InterruptedException e) {
                e.printStackTrace();
            } catch (BrokenBarrierException e) {
                e.printStackTrace();
            }
        }).start();
        new Thread(()->{
            try {
                /*等大家都到齐,人一旦到齐就可以开打球了*/
                barrier.await();
                Thread.sleep(1000);
                System.out.println("我是中锋我正在抢夺篮板球");
            } catch (InterruptedException e) {
                e.printStackTrace();
            } catch (BrokenBarrierException e) {
                e.printStackTrace();
            }
        }).start();
    }
}

代码运行结果
在这里插入图片描述

二、CyclicBarrier和CountDownLatch的比较
  • CountDownLatch的计数器只能使用一次。而CyclicBarrier的计数器可以使用reset() 方法重置,因此CyclicBarrier能处理更为复杂的业务场景,比如计算发生错误时,可以重置计数器,并让所有涉及到达线程重新执行一次
  • CyclicBarrier可以通过getNumberWaiting方法可以获得CyclicBarrier阻塞的线程数量,通过isBroken来判断阻塞的线程是否被中断
  • CountDownLatch会阻塞主线程,CyclicBarrier不会阻塞主线程,只会阻塞子线程
    关于CountDownLatch可以参考此篇文章
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值