CyclicBarrier讲解

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/weixin_41751625/article/details/89602894

   在j.u.c并发包中,还提供了一个让多个线程同时到达一个同步点的工具类CyclicBarrier,有的地方翻译为栅栏,即可以让CyclicBarrier管理几个线程,例如下图:

如上图所示,当多个线程被CyclicBarrier管理时,必须所有的线程都到达同步点,方能继续向下执行。

下面来写一些示例代码。

public class TestCyclicBarrier {

    private static CyclicBarrier cyclicBarrier=new CyclicBarrier(2);

    public static void main(String[] args) {
        new Thread(()->{
            try {
                cyclicBarrier.await();
                System.out.println(Thread.currentThread().getName()+"执行完毕");
            } catch (Exception e) {
                e.printStackTrace();
            }
        }).start();

        new Thread(()->{
            try {
                TimeUnit.SECONDS.sleep(5);
                cyclicBarrier.await();
                System.out.println(Thread.currentThread().getName()+"执行完毕");
            } catch (Exception e) {
                e.printStackTrace();
            }
        }).start();
    }
}

上面这段示例代码,可以看到两个线程会等待5秒之后才输出,一个线程快,一个线程慢,睡眠了5秒钟。但是因为同步点,第一个快的线程会阻塞在同步点,直到第二线程到达同步点才能同时向下执行。 

猜你喜欢

转载自blog.csdn.net/weixin_41751625/article/details/89602894