码迷,mamicode.com
首页 > 编程语言 > 详细

Java线程与并发编程实践----同步器(Phaser)

时间:2018-01-19 18:51:00      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:字母   for   main   break   同步器   并发   override   while   超出   

    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)

标签:字母   for   main   break   同步器   并发   override   while   超出   

原文地址:http://blog.51cto.com/12222886/2062974

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!