并发包同步工具CyclicBarrier
2017-05-25 10:40
423 查看
/** * * @描述: 同步工具 * 表示大家彼此等待,大家集合好后才开始出发,分散活动后又在指点地点集合碰合 . * @作者: 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
- (11)java5的Semaphere、CyclicBarrier同步工具
- 【java并发】线程同步工具CyclicBarrier的使用
- java并发工具CyclicBarrier的理解和使用
- 使用java并发工具栅栏(CyclicBarrier)实现多线程等待,同一时刻执行共同任务
- 并发编程工具之二:CyclicBarrier 用法
- 15.Java5的CyclicBarrier同步工具
- Java中的并发工具CountDownLatch、CyclicBarrier、Semapphore使用详解
- Java并发同步之CountDownLatch、CyclicBarrier和Semaphore
- Java并发工具类(二):同步屏障CyclicBarrier
- Java并发学习(十六)-并发工具CyclicBarrier
- Java并发同步工具类之CyclicBarrier
- Java并发之CyclicBarrier 可重用同步工具类
- java5 CyclicBarrier同步工具
- 【多线程_并发工具】 栅栏_CyclicBarrier
- Java并发编程之2——同步工具类的使用(CountDownLatch,CyclicBarrier,BlockungQueue,Semaphore)
- Java7并发编程--3.3、CyclicBarrier在集合点同步
- JAVA中的并发工具类(二)---同步屏障类CyclicBarrier
- Java并发学习之十八——线程同步工具之CyclicBarrier
- java并发之同步屏障CyclicBarrier