JAVA柵欄

壹頁書發表於2014-05-20
JAVA併發程式設計實踐 83頁

柵欄與閉鎖不同的是,柵欄可以重複使用。

  1. import java.util.concurrent.BrokenBarrierException;
  2. import java.util.concurrent.CyclicBarrier;

  3. public class Test {
  4.     // 一個同步輔助類,它允許一組執行緒互相等待,直到到達某個公共屏障點 (common barrier point)
  5.     final CyclicBarrier barrier;

  6.     // 執行緒數
  7.     int count;

  8.     class Worker implements Runnable {
  9.         int index;

  10.         Worker(int index) {
  11.             this.index = index;
  12.         }

  13.         public void run() {
  14.             System.out.println("第" + index + "個執行緒休眠" + (2 * index) + "秒!");
  15.             try {
  16.                 Thread.sleep(2000 * index);
  17.             } catch (InterruptedException e) {
  18.                 e.printStackTrace();
  19.             }
  20.             System.out.println("第" + index + "個執行緒結束休眠!");

  21.             try {
  22.                 // 等待其它執行緒都處理完畢後,再繼續以下程式碼的執行
  23.                 barrier.await();
  24.             } catch (InterruptedException e) {
  25.                 e.printStackTrace();
  26.             } catch (BrokenBarrierException e) {
  27.                 e.printStackTrace();
  28.             }

  29.             System.out.println(index);
  30.         }
  31.     }

  32.     public Test(int count) {
  33.         this.count = count;

  34.         // 公共屏障點 等待到5個執行緒後,執行相應的barrierAction
  35.         barrier = new CyclicBarrier(count, new Runnable() {
  36.             public void run() {
  37.                 System.out.println("全部執行緒已執行完畢!");
  38.             }
  39.         });

  40.         for (int i = 1; i <= this.count; i++) {
  41.             new Thread(new Worker(i)).start();
  42.         }
  43.     }

  44.     public static void main(String[] args) {
  45.         new Test(5);
  46.     }
  47. }




來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29254281/viewspace-1164727/,如需轉載,請註明出處,否則將追究法律責任。

相關文章