Phaser是一个更加弹性的同步屏障。和同步屏障一样,一个phaser使得一组线程在
屏障上等待,在最后一个线程到达之后,这些线程才得以继续执行。phaser也提供了和barrier
action等价的操作。
和同步屏障协同固定数目的线程不同,一个phaser能够协调不定数目的线程,这些
线程可以在任何时候注册。
示例代码:
下面的例子创建了3个线程,打印一些字母,但是线程创建好后并不立刻执行,而是在主程序中
对其进行控制,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(); } } }}