Java 异步线程监听与结果回调及异常捕获总结分析
前言
工作中是否遇到这样的场景?
1、需要异步线程执行,而且需要获取到线程执行返回的结果。
2、如果执行过程异常,可以按照自定义方式消费异常信息。
如果只是单纯的使用Callable可以实现,本文提供更加优雅的工具类。
Maven依赖
<dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.7.15</version> </dependency> <!-- https://mvnrepository.com/artifact/com.google.guava/guava --> <dependency> <groupId>com.google.guava</groupId> <artifactId>guava</artifactId> <version>31.0.1-jre</version> </dependency>
代码
不废话,上代码。
package com.huyi.csdn.tools; import cn.hutool.core.thread.ThreadUtil; import com.google.common.util.concurrent.*; import org.checkerframework.checker.nullness.qual.Nullable; import org.springframework.scheduling.concurrent.CustomizableThreadFactory; import java.util.concurrent.Callable; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.TimeUnit; import java.util.function.Consumer; /** * @Program: csdn @ClassName: AsyncListenUtil @Author: huyi @Date: 2021-10-30 11:48 @Description: * 异步线程监听回调工具 @Version: V1.0 */ public class AsyncListenUtil { public static final ExecutorService executorService = Executors.newFixedThreadPool(10, new CustomizableThreadFactory("LISTEN-")); public static final ListeningExecutorService listeningExecutorService = MoreExecutors.listeningDecorator(executorService); /** * 提交任务 * * @param work Callable需要线程执行的内容 * @param consumer 结果消费 * @param errorConsumer 异常消费 * @param <T> 泛型 */ public static <T> void submit( Callable<T> work, Consumer<T> consumer, Consumer<Throwable> errorConsumer) { ListenableFuture<T> listenableFuture = listeningExecutorService.submit(work); Futures.addCallback( listenableFuture, new FutureCallback<T>() { @Override public void onSuccess(@Nullable T s) { consumer.accept(s); } @Override public void onFailure(Throwable throwable) { errorConsumer.accept(throwable); } }, listeningExecutorService); } /** 摧毁线程池 */ public static void destroy() { System.out.println("摧毁线程池"); executorService.shutdown(); } public static void main(String[] args) { AsyncListenUtil.submit( () -> { // todo 需要执行的内容 ThreadUtil.sleep(10, TimeUnit.SECONDS); return "I finished my work"; }, result -> { // todo 结果处理 System.out.println("listen get :" + result); }, throwable -> { // todo 异常处理 System.out.println(throwable.getMessage()); }); ThreadUtil.sleep(20, TimeUnit.SECONDS); destroy(); } }
代码说明
1、提交方法主要参数有,需要执行的Callable,结果的Consumer,异常的Consumer。其中Callable调整成Supplier也是没什么问题。
2、提供摧毁线程池方法。
执行结果
OK没什么问题。
总结
追求优雅是个好习惯。
如果本工具对你有用的话,请点个赞吧,这对作者很重要,谢谢。
到此这篇关于Java 异步线程监听与结果回调及异常捕获总结分析的文章就介绍到这了,更多相关Java 异步线程监听内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
深入Synchronized和java.util.concurrent.locks.Lock的区别详解
本篇文章是对Synchronized和java.util.concurrent.locks.Lock的区别进行了详细的分析介绍,需要的朋友参考下2013-06-06Spring Boot整合Swagger测试api构建全纪录
这篇文章主要给大家介绍了关于Spring Boot整合Swagger测试api构建的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-01-01Java中BigDecimal,DateFormatter 和迭代器的"陷阱"
这篇文章主要介绍了Java中BigDecimal,DateFormatter 和迭代器的"陷阱",文章围绕主题展开详细的内容介绍,感兴趣的小伙伴可以参考一下2022-06-06IntelliJ IDEA中Scala、sbt、maven配置教程
这篇文章主要介绍了IntelliJ IDEA中Scala、sbt、maven配置教程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-09-09SpringBoot整合Mybatis-Plus、Jwt实现登录token设置
Spring Boot整合Mybatis-plus实现登录常常需要使用JWT来生成用户的token并设置用户权限的拦截器,本文就来详细的介绍一下,具有一定的参考价值,感兴趣的可以了解一下2024-02-02
最新评论