并发包同步工具CyclicBarrier

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了并发包同步工具CyclicBarrier相关的知识,希望对你有一定的参考价值。

/**
 * 
 * @描述: 同步工具
 * 表示大家彼此等待,大家集合好后才开始出发,分散活动后又在指点地点集合碰合 .
 * @作者: Wnj .
 * @创建时间: 2017年5月16日 .
 * @版本: 1.0 .
 */
public class CyclicBarrierTest {
    
    public static void main(String[] args) {
        ExecutorService service = Executors.newCachedThreadPool();
        //要有三个线程到了才走
        final CyclicBarrier cb = new CyclicBarrier(3);
        for (int i = 0; i < 3; i++) {
            Runnable runnable = new Runnable() {
                public void run() {
                    try {
                        Thread.sleep((long)(Math.random() * 10000));
                        
                        
                        System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点1,当前已有" 
                        + (cb.getNumberWaiting() + 1) + "个已经到达," + (cb.getNumberWaiting() == 2 ? "都到齐了,继续走啊" : "正在等候"));
                        //三个线程的第N个线程等待
                        cb.await();
                        
                        Thread.sleep((long)(Math.random() * 10000));
                        System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点2,当前已有" 
                        + (cb.getNumberWaiting() + 1)
                            + "个已经到达," + (cb.getNumberWaiting() == 2 ? "都到齐了,继续走啊" : "正在等候"));
                        
                        //三个线程的第N个线程等待
                        cb.await();
                        Thread.sleep((long)(Math.random() * 10000));
                        System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点3,当前已有"
                        + (cb.getNumberWaiting() + 1)
                            + "个已经到达," + (cb.getNumberWaiting() == 2 ? "都到齐了,继续走啊" : "正在等候"));
                        
                        //三个线程的第N个线程等待
                        cb.await();
                    }
                    catch (Exception e) {
                        e.printStackTrace();
                    }
                }
            };
            service.execute(runnable);
        }
        service.shutdown();
    }
}

 

以上是关于并发包同步工具CyclicBarrier的主要内容,如果未能解决你的问题,请参考以下文章

PHP并发包5--同步工具CountDownLatchCyclicBarrierSemaphore的实现原理解析

PHP并发包5--同步工具CountDownLatchCyclicBarrierSemaphore的实现原理解析

Java并发包中CyclicBarrier的源码分析和使用

Java并发包中CyclicBarrier的工作原理使用示例

JAVA并发包源码分析循环栅栏:CyclicBarrier

Java -- 每日一问:Java并发包提供了哪些并发工具类?