1. 程式人生 > >Java線程與並發編程實踐----同步器(Phaser)

Java線程與並發編程實踐----同步器(Phaser)

出了 dpa 主程序 public term 進行 als 同步 打印

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();
			}
		}
	}
}



Java線程與並發編程實踐----同步器(Phaser)