CompletableFuture是Java异步编程核心,支持非阻塞任务与链式调用。1. 使用supplyAsync/runAsync创建异步任务,可指定自定义线程池;2. 通过thenApply转换结果、thenAccept消费结果、thenRun执行后续动作,实现链式操作;3. 利用thenCombine合并两任务结果,allOf等待所有任务完成;4. 异常处理用exceptionally提供回退值,handle统一处理结果与异常。合理使用可提升代码可读性与执行效率,避免主线程阻塞。

在Java中,CompletableFuture 是处理异步编程的核心工具之一。它不仅支持非阻塞的任务执行,还能通过链式调用组合多个异步操作,极大提升了代码的可读性和执行效率。下面介绍几种常用的使用技巧和实际应用场景。
创建异步任务
你可以使用 CompletableFuture.supplyAsync() 或 runAsync() 来启动一个异步任务。supplyAsync 适用于有返回值的场景,而 runAsync 用于无返回值的操作。
示例:
CompletableFuturefuture = CompletableFuture.supplyAsync(() -> "Hello from async"); CompletableFuture.runAsync(() -> System.out.println("Task running in background"));
这些方法默认使用 ForkJoinPool.commonPool() 执行任务,也可以传入自定义线程池来控制资源。
立即学习“Java免费学习笔记(深入)”;
链式调用与结果转换
通过 thenApply、thenAccept 和 thenRun 可以对上一步的结果进行后续处理。
-
thenApply(Function):接收上一步结果并返回新值,可用于数据转换。 -
thenAccept(Consumer):消费结果但不返回值,适合打印或存储。 -
thenRun(Runnable):不接收参数,仅在前任务完成后执行动作。
例子:
CompletableFuture.supplyAsync(() -> "Hello") .thenApply(s -> s + " World") .thenAccept(System.out::println);
组合多个异步任务
当需要并行执行多个任务并合并结果时,可以使用 thenCombine 或 allOf。
-
thenCombine:将两个异步任务的结果合并成一个新结果。 -
CompletableFuture.allOf(future1, future2, ...):等待所有任务完成,返回 void 类型的 CompletableFuture。
示例:
CompletableFuturef1 = CompletableFuture.supplyAsync(() -> "Result1"); CompletableFuture f2 = CompletableFuture.supplyAsync(() -> "Result2"); f1.thenCombine(f2, (r1, r2) -> r1 + " | " + r2) .thenAccept(System.out::println);
异常处理机制
异步任务中发生异常不会立即抛出,需通过 exceptionally 或 handle 方法捕获。
-
exceptionally(Function):仅在发生异常时提供回退值。 -
handle(BiFunction):无论是否异常都会执行,可用于统一处理结果或错误。
示例:
CompletableFuture.supplyAsync(() -> {
throw new RuntimeException("Oops!");
})
.exceptionally(ex -> "Fallback value")
.thenAccept(System.out::println);
基本上就这些核心技巧。合理运用 CompletableFuture 能让异步逻辑更清晰、更高效,同时避免阻塞主线程。关键是理解每个方法的返回类型和执行时机,避免误用导致程序行为不符合预期。










