协调线程间同步的类之二------CyclicBarrier 学习笔记

一。

         1>CyclicBarrier类似于CountDownLatch也是个计数器,不同的是CyclicBarrier数的是调用了CyclicBarrier.await()进入等待的线程数,当线程达到了CyclicBarrier初始时规定的数目时,所有进入等待状态的线程被唤醒并继续。而CountDownLatch的作用是 只有线程中CountDownLatch被数到0时,才执行CountDownLatch对象await操作后面的逻辑功能。  想探究CountDownLatch可以参考上篇博文     

        2>CyclicBarrier就像他的名字一样,可以看成是个障碍,所有的线程必须到期后才能一起通过这个障碍

         3>CyclicBarrier初始时还可以带一个Runnable参数,此Runnable任务在CyclicBarrier的数目达到后、所有其他线程被唤醒前执行。

        4>测试代码如下



public class CyclicBarrierTest {
    public static class ComponentThread implements Runnable {
        CyclicBarrier barrier;
        int id;
        int[] array;

        public ComponentThread(CyclicBarrier barrier, int[] array, int id) {
            this.barrier = barrier;
            this.array = array;
            this.id = id;
        }

        @Override
        public void run() {
            array[id] = new Random().nextInt(100);
            System.out.println("Component " + id + "generates" + array[id]);
            try {
                barrier.await();
            } catch (InterruptedException e) {
                e.printStackTrace();
            } catch (BrokenBarrierException e) {
                e.printStackTrace();
            }
            System.out.println("Component " + id + " awaked");
            int result = array[id] + array[id + 1];
            System.out.println("Component " + id + " result:" + result);
        }
    }

    public static void testCyclicBarrier() {
        final int[] array = new int[3];
        CyclicBarrier barrier = new CyclicBarrier(2, new Runnable() {

            @Override
            public void run() {
                System.out.println("test CyclicBarrier run...");
                array[2] = array[0] + array[1];
            }
        });
        new Thread(new ComponentThread(barrier, array, 0)).start();
        new Thread(new ComponentThread(barrier, array, 1)).start();
    }

    public static void main(String[] args) {
        CyclicBarrierTest.testCyclicBarrier();
    }
}



转载于:https://my.oschina.net/u/2323537/blog/617868

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值