Phaser是一個更加彈性的同步屏障。和同步屏障同樣,一個phaser使得一組線程在
java
屏障上等待,在最後一個線程到達以後,這些線程才得以繼續執行。phaser也提供了和barrieride
action等價的操做。函數
和同步屏障協同固定數目的線程不一樣,一個phaser可以協調不定數目的線程,這些
this
線程能夠在任什麼時候候註冊。spa
示例代碼:線程
下面的例子建立了3個線程,打印一些字母,可是線程建立好後並不馬上執行,而是在主程序中orm
對其進行控制,3秒鐘後全部進程同時開始執行進程
import java.util.concurrent.Phaser; public class MyTest { public static void main(String[] args) { Phaser phaser = new Phaser(3) {// 共有3個工做線程,所以在構造函數中賦值爲3 @Override protected boolean onAdvance(int phase, int registeredParties) { System.out.println("\n=========華麗的分割線============="); return registeredParties == 0; } }; System.out.println("程序開始執行"); char a = 'a'; for (int i = 0; i < 3; i++) { // 建立並啓動3個線程 new MyThread((char) (a + i), phaser).start(); } while (!phaser.isTerminated()) {// 只要phaser不終結,主線程就循環等待 Thread.yield(); } System.out.println("程序結束"); } } class MyThread extends Thread { private char c; private Phaser phaser; public MyThread(char c, Phaser phaser) { this.c = c; this.phaser = phaser; } @Override public void run() { while (!phaser.isTerminated()) { for (int i = 0; i < 10; i++) { // 將當前字母打印10次 System.out.print(c + " "); } // 打印完當前字母后,將其更新爲其後第三個字母,例如b更新爲e,用於下一階段打印 c = (char) (c + 3); if (c > 'z') { // 若是超出了字母z,則在phaser中動態減小一個線程,並退出循環結束本線程 phaser.arriveAndDeregister(); break; } else { // 反之,等待其餘線程到達階段終點,再一塊兒進入下一個階段 phaser.arriveAndAwaitAdvance(); } } } }