CyclicBarrier


CyclicBarrier java.util.concurrent

Java 5.0

This class synchronizes a group of n threads, where n is specified to the CyclicBarrier( ) constructor. Threads call the await( ) method, which blocks until n threads are waiting. In the simple case, all n threads are then allowed to proceed, and the CyclicBarrier resets itself until it has another n threads blocked in await( ) .

More complex behavior is possible if you pass a Runnable object to the CyclicBarrier constructor. This Runnable is a " barrier action" and when the last of the n threads invokes await( ) , that method uses the thread to invoke the run( ) method of the Runnable . This Runnable is typically used to perform some sort of coordinating action on the blocked threads. When the run( ) method returns, the CyclicBarrier allows all blocked threads to resume.

When threads resume from await( ) , the return value of await( ) is an integer that represents the order in which they called await( ) . This is useful if you want to be able to distinguish between otherwise identical worker threads. For example, you might have the thread that arrived first perform some special action while the remaining threads resume.

If any thread times out or is interrupted while blocked in await( ) , the CyclicBarrier is said to be "broken," and all waiting threads (and any threads that subsequently call await( ) ) wake up with a BrokenBarrierException . Waiting threads also receive a BrokenBarrierException if the CyclicBarrier is reset( ) . The reset( ) method is the only way to restore a broken barrier to its initial state. This is difficult to coordinate properly, however, unless one controller thread is coded differently from the other threads at the barrier.

 public class  CyclicBarrier  {  // Public Constructors  public  CyclicBarrier  (int  parties  );        public  CyclicBarrier  (int  parties  , Runnable  barrierAction  );  // Public Instance Methods  public int  await  ( ) throws InterruptedException, BrokenBarrierException;        public int  await  (long  timeout  , TimeUnit  unit  )          throws InterruptedException, BrokenBarrierException, TimeoutException;        public int  getNumberWaiting  ( );        public int  getParties  ( );        public boolean  isBroken  ( );        public void  reset  ( );   } 



Java In A Nutshell
Java In A Nutshell, 5th Edition
ISBN: 0596007736
EAN: 2147483647
Year: 2004
Pages: 1220

flylib.com © 2008-2017.
If you may any questions please contact us: flylib@qtcs.net