CompletableFuture 使用详解

CompletableFuture 使用详解

1. 简介

CompletableFuture 是 Java 8 中的一个类,提供了一种更为简洁和灵活的方式来处理异步任务和并发编程。它可以用于启动异步计算,处理计算完成后的结果,组合多个计算,以及处理异常等。
主要使用场景

  • 异步计算:用于异步执行任务而不阻塞主线程。 并发任务管理:处理多个并发任务,并协调它们的结果。
  • 复杂的异步流程:处理多个阶段的计算,每个阶段的结果依赖于前一个阶段。 CompletableFuture

2. 创建 CompletableFuture

可以通过多种方式创建 CompletableFuture 实例:

2.1 创建一个已经完成的 CompletableFuture

CompletableFuture<String> completedFuture = CompletableFuture.completedFuture("Hello, World!");

2.2 使用工厂方法创建异步任务

CompletableFuture<Void> future = CompletableFuture.runAsync(() -> {
    // 异步执行任务
});

2.3 使用 supplyAsync 创建异步计算任务

CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> {
    // 返回计算结果
    return 123;
});

3. 处理结果

CompletableFuture 提供了多种方法来处理异步任务的结果。

3.1 thenApply thenApplyAsync

用于处理计算完成后的结果,并返回一个新的 CompletableFuture。

CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> 10);
CompletableFuture<Integer> result = future.thenApplyAsync(value -> value * 2);
result.thenAccept(System.out::println);  // 输出 20

3.2 thenAcceptthenAcceptAsync

用于处理计算完成后的结果,但不返回新的 CompletableFuture。


CompletableFuture.supplyAsync(() -> "Hello")
    .thenAccept(result -> System.out.println(result));  // 输出 "Hello"

3.3 thenCombinethenCombineAsync

用于组合两个 CompletableFuture 的结果。

CompletableFuture<Integer> future1 = CompletableFuture.supplyAsync(() -> 10);
CompletableFuture<Integer> future2 = CompletableFuture.supplyAsync(() -> 20);
CompletableFuture<Integer> combined = future1.thenCombine(future2, (x, y) -> x + y);
combined.thenAccept(System.out::println);  // 输出 30

4. 异常处理

4.1 exceptionally

用于处理异步计算中的异常。

CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> {
    if (true) throw new RuntimeException("Exception occurred!");
    return 1;
}).exceptionally(ex -> {
    System.err.println(ex.getMessage());
    return 0;
});

4.2 handle

handle 方法既处理计算结果,也处理异常。

CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> {
    if (true) throw new RuntimeException("Exception occurred!");
    return 1;
}).handle((result, ex) -> {
    if (ex != null) {
        System.err.println(ex.getMessage());
        return 0;
    }
    return result;
});

5. 等待多个任务

5.1 allOf

用于等待所有的 CompletableFuture 完成。

C

ompletableFuture<Void> future1 = CompletableFuture.runAsync(() -> {
    // 任务1
});
CompletableFuture<Void> future2 = CompletableFuture.runAsync(() -> {
    // 任务2
});
CompletableFuture<Void> allOf = CompletableFuture.allOf(future1, future2);
allOf.join();  // 阻塞,直到所有任务完成

5.2 anyOf

用于等待第一个 CompletableFuture 完成。

CompletableFuture<Void> future1 = CompletableFuture.runAsync(() -> {
    // 任务1
});
CompletableFuture<Void> future2 = CompletableFuture.runAsync(() -> {
    // 任务2
});
CompleableFuture<Object> anyOf = CompletableFuture.anyOf(future1, future2);
anyOf.join();  // 阻塞,直到任意一个任务完成

6.使用示例

 ExecutorService executor = Executors.newFixedThreadPool(resourceConfig.getThreadNum());
                List<Object>> list = Lists.newArrayList<>();
                CompletableFuture<?>[] tasks = list.stream()
                        .map(item -> CompletableFuture.runAsync(() -> processRecords(item), executor))
                        .toArray(CompletableFuture[]::new);
                CompletableFuture.allOf(tasks).join();
                executor.shutdown();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值