Java线程总结(十一):并发包------CyclicBarrier
来源:互联网 发布:淘宝挂机软件是真的吗 编辑:程序博客网 时间:2024/05/16 02:07
package com.ydj;import java.util.concurrent.CyclicBarrier;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;public class CyclicBarrierTest {/** * 表示大家彼此等待,大家集合好后才开始出发,分散活动后又在指定地点集合碰面。 * * 这就好比整个公司的人员利用周末时间集体郊游一样: * 先各自从家出发到公司集合后(没有集合则等待), 再同时出发到公园游玩, * 在指定地点集合后(没有集合则等待)再同时开始就餐 */public static void main(String[] args) {ExecutorService service = Executors.newCachedThreadPool();final CyclicBarrier cb = new CyclicBarrier(3);//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?"都到齐了,继续走啊":"正在等候"));cb.await();//如果3个线程没有全部到达,就等待Thread.sleep((long)(Math.random()*10000));System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点2,当前已有" + (cb.getNumberWaiting()+1) + "个已经到达," + (cb.getNumberWaiting()==2?"都到齐了,继续走啊":"正在等候"));cb.await();//如果3个线程没有全部到达,就等待Thread.sleep((long)(Math.random()*10000));System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点3,当前已有" + (cb.getNumberWaiting() + 1) + "个已经到达," + (cb.getNumberWaiting()==2?"都到齐了,继续走啊":"正在等候"));cb.await();//如果3个线程没有全部到达,就等待} catch (Exception e) {e.printStackTrace();}}};service.execute(runnable);}service.shutdown();}}
运行结果:
0 0
- Java线程总结(十一):并发包------CyclicBarrier
- Java并发包之CyclicBarrier
- Java线程总结(五):并发包------线程池Executors
- Java线程总结(六):并发包------线程同步Lock
- Java线程总结(七):并发包------线程通信condition
- Java并发库(十五):线程等待CyclicBarrier
- Java线程(CountDownLatch、CyclicBarrier、Semaphore)并发控制工具类
- Java并发包:CountDownLatch和CyclicBarrier
- Java线程总结(十二):并发包------CountDownLatch
- Java线程总结(九):并发包------控制并发线程数Semaphore
- 线程并发工具--CyclicBarrier
- java高并发程序设计总结五:jdk并发包其他同步控制工具类:ReadWriteLock/CountDownLatch/CyclicBarrier/LockSupport
- Java线程(十):CyclicBarrier-用路障实现分阶段线程并发
- Java线程(十):CyclicBarrier-用路障实现分阶段线程并发
- Java线程总结(十):并发包------两个线程交换数据Exchanger
- Java线程总结(十三):并发包------线程返回结果Callable和 Future
- [Java并发包学习五]CountDownLatch和CyclicBarrier介绍
- [Java并发包学习五]CountDownLatch和CyclicBarrier介绍
- 约汗——基于Android的大学生找伙伴约运动app 开发总结
- DAY03 构造函数及调用、继承行为,接口
- C++与Java比较
- MFC动态改变对话框窗口大小和显示位置
- poj 1990 MooFest
- Java线程总结(十一):并发包------CyclicBarrier
- 介绍一下索引
- maven_pom解析
- Swift枚举详解
- POJ 2007 极角排序
- StackOverflow: 你没见过的七个最好的Java答案
- cs231n-(5)神经网络-1:建立架构
- 支付宝接口编码不规范问题
- 分享一个自己写的用python比对数据库表数据的脚本