CyclicBarrier公共屏障点:一个同步辅助类,它允许一组线程互相等待
来源:互联网 发布:xo网络用语是什么意思 编辑:程序博客网 时间:2024/06/05 21:01
一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier
point)。在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待,此时
CyclicBarrier 很有用。因为该 barrier 在释放等待线程后可以重用,所以称它为循环 的
barrier。
package jingtianxiaozhi;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);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();Thread.sleep((long)(Math.random()*10000));System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点2,当前已有" + (cb.getNumberWaiting()+1) + "个已经到达," + (cb.getNumberWaiting()==2?"都到齐了,继续走啊":"正在等候"));cb.await();Thread.sleep((long)(Math.random()*10000));System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点3,当前已有" + (cb.getNumberWaiting() + 1) + "个已经到达," + (cb.getNumberWaiting()==2?"都到齐了,继续走啊":"正在等候"));cb.await();} catch (Exception e) {e.printStackTrace();}}};service.execute(runnable);}service.shutdown();}}
运行结果
线程pool-1-thread-2即将到达集合地点1,当前已有1个已经到达,正在等候线程pool-1-thread-1即将到达集合地点1,当前已有2个已经到达,正在等候线程pool-1-thread-3即将到达集合地点1,当前已有3个已经到达,都到齐了,继续走啊线程pool-1-thread-1即将到达集合地点2,当前已有1个已经到达,正在等候线程pool-1-thread-2即将到达集合地点2,当前已有2个已经到达,正在等候线程pool-1-thread-3即将到达集合地点2,当前已有3个已经到达,都到齐了,继续走啊线程pool-1-thread-2即将到达集合地点3,当前已有1个已经到达,正在等候线程pool-1-thread-1即将到达集合地点3,当前已有2个已经到达,正在等候线程pool-1-thread-3即将到达集合地点3,当前已有3个已经到达,都到齐了,继续走啊
- CyclicBarrier公共屏障点:一个同步辅助类,它允许一组线程互相等待
- 类 Semaphore(一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 )
- JAVA多线程—CyclicBarrier-一个同步辅助类,它允许一组线程互相等待
- CountDownLatch,一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待
- JAVA多线程—CountDownLatch-一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待。
- CyclicBarrier 公共屏障点
- CyclicBarrier 公共屏障点
- java CyclicBarrier (栅栏) 作用是使 指定个数的请求线程互相等待, 拦截在某个公共屏障点(就是栅栏外面)然后全到齐了一起访问这个屏障点的内容
- 同步辅助类CyclicBarrier
- Java 多线程 线程互相等待 CyclicBarrier
- 并发编程实战手册-线程同步辅助类之CyclicBarrier
- CyclicBarrier -- 同步辅助类2
- 并发工具类:同步屏障CyclicBarrier
- 同步屏障CyclicBarrier
- 同步屏障CyclicBarrier
- 同步屏障CyclicBarrier
- 同步屏障CyclicBarrier
- 同步屏障CyclicBarrier
- WebService第三步 - 项目开发实战1
- 【黑马程序员】 学习笔记 - Java正则表达式
- gcc中-pthread和-lpthread的区别
- 使用C语言实现二维,三维绘图算法(3)-简单的二维分形
- 2013年美国开发者薪资调查报告
- CyclicBarrier公共屏障点:一个同步辅助类,它允许一组线程互相等待
- 精选30道Java笔试题解答
- 修改大文件pilotedit
- 线性方程组的几何解释
- Morn UI 学习总结
- cocos2d-x animation闪烁与plist文件读取
- 如何通过经纬度获取地址信息?
- ubuntu下arm-linux-gcc的问题
- 输出四个整数中的最大值