Java 障碍器
来源:互联网 发布:网络信息监控采集技术 编辑:程序博客网 时间:2024/04/29 07:11
简介:
CyclicBarrier就象它名字的意思一样,可看成是个障碍, 所有的线程必须到齐后才能一起通过这个障碍。
当所有的任务都达到障碍点的时候,最后的任务才会被执行。
DOC:
一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point)。在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待,此时 CyclicBarrier 很有用。因为该 barrier 在释放等待线程后可以重用,所以称它为循环 的 barrier。
CyclicBarrier 支持一个可选的 Runnable 命令,在一组线程中的最后一个线程到达之后(但在释放所有线程之前),该命令只在每个屏障点运行一次。若在继续所有参与线程之前更新共享状态,此屏障操作 很有用。
Demo:
class PartTask implements Runnable{//指向障碍器的引用CyclicBarrier cb;//子任务的名称String ptname;//代表子任务的持续时间int duringTime;//构造器public PartTask(CyclicBarrier cb,String ptname,int duringTime){this.cb=cb;this.ptname=ptname;this.duringTime=duringTime;}//表示任务的方法public void run(){System.out.println(ptname+"子任务开始执行!!!");try{Thread.sleep(duringTime);System.out.println(ptname+"子任务执行结束!!!");//子任务结束,调用await方法通知障碍器//Thread.sleep(millis)cb.await();}catch(Exception e){e.printStackTrace();}}}//表示所有子任务结束后任务的类class FinalTask implements Runnable{//表示任务的方法public void run(){System.out.println("最后的任务被执行!!!");}}//主类public class Mian{public static void main(String args[]){ //创建障碍器对象,并指定最后的任务 CyclicBarrier cb=new CyclicBarrier(5,new FinalTask()); //创建线程池对象 ExecutorService threadPool=Executors.newFixedThreadPool(5); //启动5个子任务 for(int i=0;i<5;i++) { threadPool.execute(new PartTask(cb,"PartTask"+i,1000+i*1000)); } //关闭线程池 threadPool.shutdown();}}
ps:代码来自《Java SE 6.0编程指南》
参考:
http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/CyclicBarrier.html
http://www.cnblogs.com/techyc/archive/2013/03/13/2957059.html
http://www.blogjava.net/jlins-you/archive/2012/04/24/376516.html
http://item.jd.com/10062576.html
- Java 障碍器
- java多线程--障碍器
- java线程 障碍器
- Java线程:新特征-障碍器
- Java线程:新特征-障碍器
- Java线程:新特征-障碍器(1)
- Java线程:新特征-障碍器(2)
- Java线程:新特征-障碍器
- Java线程:新特征-障碍器
- Java线程:新特征-障碍器
- Java线程:新特征-障碍器
- Java线程:新特征-障碍器
- Java线程:新特征-障碍器
- Java线程:新特征-障碍器
- Java线程:新特征-原子量,障碍器
- java并发之CyclicBarrier(障碍器)
- Java线程:新特征-障碍器
- Java线程:新特征-障碍器
- java中的事物管理
- 界面编程:VC实现自绘窗体标题栏非客户区
- WinddowManager
- 谈谈 WLST Custom Commands
- 文件之后xml及jsp等各种页面中的部分显示异常问题
- Java 障碍器
- ICMP协议
- Android中asset文件夹和raw文件夹区别
- TCP/IP协议栈与数据包封装
- 项目总结——再谈事务机制
- Callable,Runnable比较及用法
- 执行./ggsci报错error while loading shared libraries: libnnz10.so
- Android 4.0 隐藏虚拟按键(导航栏)的方法
- vi出的提示** already locked,session is read-only