栅栏CyclicBarrier

该博客探讨了CyclicBarrier在多线程编程中的应用,它用于协调多个线程,使得它们必须集体等待直到所有线程都达到特定点才能继续执行。通过一个细胞自动衍生系统的例子展示了如何使用CyclicBarrier来同步任务,每个Worker线程在更新子板后在栅栏处等待,直到所有线程完成其工作,然后一起进入下一回合。如果出现中断或超时,CyclicBarrier会抛出异常。
摘要由CSDN通过智能技术生成

栅栏类似于闭锁,能阻塞一组线程直到某个事件发生,栅栏与闭锁的关键区别在于,所有线程必须同时到达栅栏位置,才能继续执行,闭锁用于等待事件,栅栏用于等待线程,栅栏用于实现一些协议,例如几个家庭在什么地方集合,在协商下一步的事情

CyclicBarrier可以使一定数量的问题拆分成一系列相互独立的子问题,当线程到达栅栏位置时将调用await方法,这个方法将阻塞直到所有线程都到达这个位置,如果所有线程都到达这个位置,这个栅栏将打开,线程释放。

如果await的调用超时,或者线程被中断,会抛出BarrierBrokenException

//CyclicBarrier协调细胞自动衍生系统中的计算
public class cellularAutomata{
  private final Board mainBoard;
  private final CyclicBarrier barrier;
  private final Worker[] workers;

  public cellularAutomata(Board board){
    this.mainBoard = board;
    int count = Runtime.getRuntime().availableProcessors();
    this.barrier = new CyclicBarrier(count,new Runnable(){
     public void run(){
       mainBoard.commitNewValue();
     }
   }
  });
  this.workers = new Worker[count];
  for(int i = 0;i<count;i++){
    workers[i] = new Worker(mainBoard.getSubboard(count,i));
  }

  private class Worder implements Runnable{
    private final Board board;
    public Worder(Board board){this.board = board;}

    public void run(){
      while(!board.hasConverged()){
        for(int x = 0;x<board.getMaxX();x++){
          for(int y = 0;y<board.getMaxY();y++){
            board.setNewValue(x,y,computeValue(x,y));
          }
        }
        try{
          barrier.await();
        }catch(InterruptedException ex){
          return;
        }catch(BrokenBarrierException ex){
          return;
        }
      }
    }
  }

  public void start(){
    for(int i = 0;i<workers.length;i++){
      new Thread(workers[i]).start();
    }
    mainBoard.waitForConvergence();
  }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值