java CyclicBarrier

使用情况:你希望创建一组任务,他们并行执行,然后再进行下一个步骤之前等待,直到所有任务都完成

下面是一个赛马的例子,挺有意思的(java编程思想)

import java.util.concurrent.*;
import java.util.*;

public class Horse implements Runnable {

	private static int counter=0;
	private final int id=counter++;
	private int strides=0;
	private static Random rand=new Random(47);
	private static CyclicBarrier barrier;
	public Horse(CyclicBarrier barrier){
		this.barrier=barrier;
	}
	public synchronized int getStrides(){
		return strides;
	}
	@Override
	public void run() {
		// TODO Auto-generated method stub
		try{
			while(!Thread.interrupted()){
				synchronized(this){
					strides+=rand.nextInt(3);
				}
				barrier.await();
			}
		}
		catch(InterruptedException e){}
		catch(BrokenBarrierException e){
			throw new RuntimeException(e);
		}

	}
	public String toString(){
		return "Horse "+id+" ";
	}
	public String tracks(){
		StringBuilder s=new StringBuilder();
		for(int i=0;i<getStrides();i++){
			s.append("*");
		}
		s.append(id);
		return s.toString();
	}
}

import java.util.concurrent.*;
import java.util.*;

public class HorseRace {
	public static final int FINISH_LINE=75;
	private List<Horse> horses =new ArrayList<Horse>();
	private ExecutorService exec=Executors.newCachedThreadPool();
	private CyclicBarrier barrier;
	public HorseRace(int nHorses,final int pause){
		barrier=new CyclicBarrier(nHorses,new Runnable(){
			public void run(){
				StringBuilder  s=new StringBuilder();
				for(int i=0;i<FINISH_LINE;i++)
					s.append("=");
				System.out.println(s);
				for(Horse horse:horses)
					System.out.println(horse.tracks());
				for(Horse horse:horses){
					if(horse.getStrides()>=FINISH_LINE){
						System.out.println(horse+" won!");
						exec.shutdownNow();
						return;
					}
					try{
						TimeUnit.MILLISECONDS.sleep(pause);
					}catch(InterruptedException e){
						System.out.println("barrier-action sleep interrupted");
					}
				}
			}
		});
		for(int i=0;i<nHorses;i++){
			Horse horse=new Horse(barrier);
			horses.add(horse);
			exec.execute(horse);
		}
	}

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		int nHorses=7;
		int pause=200;
		new HorseRace(nHorses,pause);

	}

}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值