Java之CyclicBarrier使用
2015-06-14 22:44
507 查看
1:CyclicBarrier类说明
一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point)。在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待,此时
CyclicBarrier 很有用。因为该 barrier 在释放等待线程后可以重用,所以称它为循环 的 barrier
2:使用场景
需要所有的子任务都完成时,才执行主任务,这个时候就可以选择使用CyclicBarrier
3:查看api
现在写一个demo玩下,
一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (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("一起泡妞去"); } }
相关文章推荐
- spring mvc messageConverters及406等问题
- java链表
- java线程和进程(运用多线程的小球碰撞游戏)
- Java 信号量 Semaphore 介绍
- java实现简单的窗体和密码验证(传参,事件机制和事件监听的作用过程)
- java图形界面基础之画图(使用Graphics类从画图形到图片到gif)
- java的数组队列和泛型
- java jtable mysql 练习与思考
- java的对象克隆技术clone()之浅度克隆(shallow Clone)
- java 框架基础知识(4)----XML基础知识-->Spring配置
- Struts2----带参数转发到JSP
- java学习笔记(六):关于iterator.next()
- Java基础之基础语法
- Java中的日志——Java.util.logging、log4j、commons-logging
- Java中的return语句使用总结
- 《Java程序设计》第二次作业:MySQL数据库及Java操作MySQL数据库
- MyBatis3整合Spring3、SpringMVC3
- Java程序设计基础项目总结报告
- Java学习笔记(八):Map<stirng,string>的遍历的四种方法
- java 使用Callable和Future返回线程执行的结果