我们在前面的文章学习CountDownLatch和CyclicBarrier的时候了解到,CountDownLatch计数器只能使用一次,不能重复利用,CyclicBarrier虽然可以重复利用但是parties在初始化时指定后就不能再修改了,所以用法上不是很灵活。
Phaser是JDK1.7引入的多线程同步工具,其功能类似于CountDownLatch和CyclicBarrier的合集,它提供的方法更灵活和丰富,但是使用难度也比较大。
目录
Phaser用作CountDownLatch
CountDownLatch能完成的功能,Phaser也能实现,其实现方式如下:
public static void main(String[] args) {
//初始化不指定parties数量,parties默认为0
final Phaser phaser = new Phaser();
//主线程调用register,数量+1
phaser.register();
IntStream.range(0,5).forEach(i ->
new Thread(()->{
//线程调用register方法,数量+1
phaser.register();
try {
//模拟业务执行时间
TimeUnit.SECONDS.sleep(new Random().nextInt(2));
System.out.println(Thread.currentThread().getName()+"完成任务");
//线程完成任务调用arrive方法,不阻塞
phaser.arrive();
} catch (InterruptedException e) {
e.printStackTrace();
}
}, "T-" + i).start()
);
//主线程arrive,但是它要等待第一个阶段结束,其前提是所有的线程都要arrive
phaser.arriveAndAwaitAdvance();
System.out.println("注册的任务数量:"+phaser.getRegisteredParties());
System.out.println