使用CompletableFuture多线程处理

本文详细介绍了如何使用Java的CompletableFuture类进行异步编程,包括工具列表创建、CompletableFuture链的构建、任务完成等待以及异常处理方法。通过流式编程实现任务并发执行,同时处理成功和失败情况。
摘要由CSDN通过智能技术生成

如何使用 Java 的 `CompletableFuture` 类来进行异步编程,同时处理成功和失败的情况。代码分为以下几个部分:

1. 工具列表创建

List<String> tools = Arrays.asList("q,w,e,r".split(","));

这一部分创建了一个包含字符串元素的列表,这些字符串将会作为异步任务的输入数据。

2. 创建 CompletableFuture 链

List<CompletableFuture<String>> futures = tools.stream()
       .map(item -> CompletableFuture.completedFuture(item).thenApplyAsync(data -> {
           // 业务处理
           String processedData = processData(data);
           System.out.println("Processed data: " + processedData);
           return processedData;
       }).exceptionally(ex -> {
           // 异常处理
           handleException(ex);
           return null;
       })
   ).collect(Collectors.toList());

在这部分,使用流式编程对工具列表中的每个元素创建了一个 `CompletableFuture`。对于每个元素,首先使用 `CompletableFuture.completedFuture` 方法将其转换为已完成的 `CompletableFuture`。然后,通过 `thenApplyAsync` 方法,在异步任务完成后对数据进行处理(通过调用 `processData` 方法)。如果任务成功,会返回处理后的数据;如果任务失败(抛出异常),会进入 `exceptionally` 块,并调用 `handleException` 方法进行异常处理。

3. 等待所有 CompletableFuture 完成

CompletableFuture<Void> allOf = CompletableFuture.allOf(futures.toArray(new CompletableFuture[0]));
allOf.join();

在这一步,使用 `CompletableFuture.allOf` 方法将所有的 `CompletableFuture` 对象合并成一个新的 `CompletableFuture`,这个新的 `CompletableFuture` 会在所有子任务都完成后完成。`join` 方法等待所有任务完成。

4.数据处理和异常处理方法

   private static String processData(String data) {
       // 模拟业务处理
       if (data.equals("e")) {
           throw new RuntimeException("自定义错误");
       }
       return data.toUpperCase();
   }

   private static void handleException(Throwable ex) {
       // 模拟异常处理,打印错误信息
       System.err.println("Exception occurred: " + ex.getMessage());
       throw new RuntimeException(ex.getMessage());
   }

这两个方法分别模拟了业务数据处理和异常处理。`processData` 方法将输入的字符串转换为大写字母,如果输入是 "e",则会抛出一个模拟异常。`handleException` 方法简单地打印异常信息并再次抛出异常。


这个代码片段演示了如何使用 CompletableFuture 来创建异步任务,并在任务处理成功或失败时进行相应的处理。在代码中处理了异常,尽管在 exceptionally 块中抛出了新的异常,但实际上这样做可能会导致异常不被完全捕获,这可能不是你想要的行为。通常情况下,最好是在 exceptionally 块中进行日志记录或其他适当的处理,而不是再次抛出异常。

另外,要注意在 handleException 方法中抛出了一个新的 RuntimeException,这可能会影响异常处理流程。通常建议在异常处理方法中避免再次抛出异常,而是根据具体情况决定如何处理异常。

CompletableFutureJava 8 引入的一个类,用于支持异步编程和多线程事务。它提供了一种方便的方式来处理异步任务以及它们之间的依赖关系。 在使用 CompletableFuture 进行多线程事务时,你可以通过创建 CompletableFuture 实例来表示需要执行的任务。然后,你可以通过调用特定的方法来处理任务的完成情况,例如 thenApply()、thenAccept()、thenRun()、thenCompose() 等。 以下是一个示例,展示了如何使用 CompletableFuture 进行多线程事务: ```java import java.util.concurrent.CompletableFuture; public class CompletableFutureExample { public static void main(String[] args) { // 创建 CompletableFuture 实例 CompletableFuture<String> future1 = CompletableFuture.supplyAsync(() -> { // 执行任务1 return "Result of Task 1"; }); CompletableFuture<String> future2 = CompletableFuture.supplyAsync(() -> { // 执行任务2 return "Result of Task 2"; }); // 处理任务的完成情况 CompletableFuture<String> combinedFuture = future1.thenCombine(future2, (result1, result2) -> { // 对任务1和任务2的结果进行处理 return result1 + " and " + result2; }); // 获取最终结果 String combinedResult = combinedFuture.join(); System.out.println(combinedResult); } } ``` 在上面的示例中,我们创建了两个 CompletableFuture 实例 `future1` 和 `future2`,分别表示任务1和任务2。然后,我们使用 `thenCombine()` 方法来处理任务的完成情况,并将两个任务的结果进行合并。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不惑_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值