Java 障碍器

简介:

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


 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值