Java 多线程等待优雅的实现方式之Phaser同步屏障

网友投稿 299 2022-09-16


Java 多线程等待优雅的实现方式之Phaser同步屏障

前言

是否会遇到这样的场景,你向线程池提交了多个任务,你希望这批任务全部完成后能够反向通知你。

你可能会使用线程计数的方式,等到计数器累加到提交的线程数量,然后通知。emmm,不是不可以,只是不够优雅。本文提供优雅的实现方式,Phaser同步屏障。

Maven依赖

也可以不依赖,本人习惯把代码简单化,使用了hutool,所以依赖只有这个。

cn.hutool

hutool-all

5.7.15

代码

废话不多说,上代码。

package com.huyi.csdn.tools;

import cn.hutool.core.thread.ThreadUtil;

import java.util.ArrayList;

import java.util.List;

import java.util.Random;

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

import java.util.concurrent.Phaser;

import java.util.concurrent.TimeUnit;

/**

* @Program: csdn @ClassName: PhaserUtil @Author: huyi @Date: 2021-11-06 21:03 @Description:

* 多线程监控回调工具 @Version: V1.0

*/

public class PhaserUtil {

public static final ExecutorService executorService = Executors.newFixedThreadPool(50);

public static class CustomPharser extends Phaser {

private final RuTtTrCxHgWqnnable runnable;

public CustomPharser(Runnable runnable) {

this.runnable = runnable;

}

@Override

protected boolean onAdvance(int phase, int registeredParties) {

this.runnable.run();

return super.onAdvance(phase, registeredParties);

}

}

/**

* 提交任务以及完成后需要执行的内容

*

* @param tasks 任务

* @param complete 完成任务

*/

public static void submit(List tasks, Runnable complete) {

Phaser phaser = new CustomPharser(complete);

for (Runnable runnable : tasks) {

executorService.submit(

() -> {

phaser.register();

runnable.run();

System.out.println(Thread.currentThread().getName() + "完成任务!");

phaser.arriveAndAwaitAdvance();

});

}

}

/** 摧毁线程池 */

pTtTrCxHgWqublic static void destroy() {

System.out.println("摧毁线程池");

executorService.shutdown();

}

public static void main(String[] args) {

List tasks = new ArrayList<>();

Random random = new Random();

for (int i = 0; i < 10; i++) {

tasks.add(

() -> {

ThreadUtil.sleep(random.nextInt(10), TimeUnit.SECONDS);

});

}

submit(tasks, () -> System.out.println("所有任务已完成"));

ThreadUtil.sleep(20, TimeUnit.SECONDS);

destroy();

}

}

代码说明

1、提交任务执行的方式是Runnable也好,Callable也好,或者Consumer、Function等等,不影响,你可以看着调整。

2、完成后的Runnable也和第一点同理。

验证一下

OK,没什么问题。

总结

其实我一直想分享一些可以让读者工作中能用到的东西,想到牧神记里面的一句话,圣人之道,无非就是百姓日用。emmmm,又废话了。

分享一下:

没必要的事就不做,必要的事就尽快做。---冰果

如果本文对你有用,请不要吝啬你的赞,谢谢。

以上就是Java 多线程等待优雅的实现方式之Phaser同步屏障的详细内容,更多关于Java 多线程等待的资料请关注我们其它相关文章!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:网络丢包,网络延迟?这款神器帮你搞定所有!(加速网络丢包)
下一篇:OSPF协议(实验篇)基本虚链路配置实验(ospf路由协议配置实验原理)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~