Java之CyclicBarrier使用
来源:互联网 发布:淘宝店铺代运营广告 编辑:程序博客网 时间:2024/05/19 14:39
1:CyclicBarrier类说明
一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point)。在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待,此时 CyclicBarrier 很有用。因为该 barrier 在释放等待线程后可以重用,所以称它为循环 的 barrier
2:使用场景
需要所有的子任务都完成时,才执行主任务,这个时候就可以选择使用CyclicBarrier
3:查看api
现在写一个demo玩下,
package cn.kge.com.thread;import java.io.IOException;import java.util.Random;import java.util.concurrent.BrokenBarrierException;import java.util.concurrent.CyclicBarrier;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;public class CyclicBarrierTest {public static void main(String[] args) throws IOException, InterruptedException { //如果将参数改为4,但是下面只加入了3个选手,这永远等待下去 //Waits until all parties have invoked await on this barrier. CyclicBarrier barrier = new CyclicBarrier(4); ExecutorService executor = Executors.newFixedThreadPool(4); executor.submit(new Thread(new Runner(barrier, "张三"))); executor.submit(new Thread(new Runner(barrier, "李四"))); executor.submit(new Thread(new Runner(barrier, "王五"))); executor.submit(new Thread(new Runner(barrier, "老刘"))); executor.shutdown(); } } class Runner implements Runnable { // 一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point) private CyclicBarrier barrier; private String name; public Runner(CyclicBarrier barrier, String name) { super(); this.barrier = barrier; this.name = name; } @Override public void run() { try { Thread.sleep(1000 * (new Random()).nextInt(8)); System.out.println(name + " 马上到..."); // barrier的await方法,在所有参与者都已经在此 barrier 上调用 await 方法之前,将一直等待。 barrier.await(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } System.out.println("一起泡妞去"); } }
0 0
- Java之CyclicBarrier使用
- Java之CyclicBarrier使用
- Java之CyclicBarrier使用
- Java之CyclicBarrier使用
- Java之CyclicBarrier使用
- Java之CyclicBarrier使用
- Java之CyclicBarrier使用
- Java之CyclicBarrier使用
- Java多线程之~~~CyclicBarrier 类的使用
- Java并发编程之CyclicBarrier的使用
- Java多线程之CyclicBarrier
- Java多线程之CyclicBarrier
- java-concurrent之CyclicBarrier
- Java线程之CyclicBarrier
- JAVA多线程之CyclicBarrier
- Java多线程之CyclicBarrier
- java线程之CyclicBarrier
- Java多线程之CyclicBarrier
- 实现InstaMaterial概念设计 - 完结篇
- VS中建立dll和lib项目总结
- 集电极开路输出、开漏输出、推挽输出
- spring mvc messageConverters及406等问题
- clog,cout,cerr 输出机制
- Java之CyclicBarrier使用
- Allegro里隐藏GND或者电源网络的鼠线/ 显示隐藏的鼠线,修改网络颜色
- 听Jake Wharton讲如何成为更优秀的开发者与创建一个成功的开源项目
- Daily mood
- Effective C++ 条款01解读: 视C++为一个语言联邦
- 如何让两个div并排同行显示
- 黑马程序员——Java面向对象(三)之内部类、异常、包等
- Android 中 ViewFlipper 的简单实例
- Hadoop的一个变长long编码剖析