Future仅支持阻塞获取结果,CompletableFuture则提供非阻塞回调、任务组合与链式调用,如supplyAsync后接thenApply实现异步编排,且支持异常处理与线程池控制,更适用于现代异步编程。
Future 接口和 CompletableFuture 都是 Java 中用于异步编程的工具,但它们在功
能、使用方式和灵活性上有显著区别。
Future 是从 Java 5 开始引入的接口,表示一个异步计算的结果。它提供了一些基本方法来检查任务是否完成、获取结果或取消任务。
主要方法包括:
它的局限在于:
CompletableFuture 是 Java 8 引入的类,实现了 Future 和 CompletionStage 接口,提供了更强大的异步编程能力。
它解决了 Future 的痛点,主要优势有:
假设我们要异步获取用户信息后再查询订单:
使用 Future:
需要手动提交任务到线程池,get() 会阻塞,难以链式处理:ExecutorService executor = Executors.newFixedThreadPool(2); FutureuserFuture = executor.submit(() -> fetchUser()); User user = userFuture.get(); // 阻塞 Future orderFuture = executor.submit(() -> fetchOrder(user.getId())); Order order = orderFuture.get(); // 再次阻塞
使用 CompletableFuture:
无需显式管理线程,支持链式调用,非阻塞:CompletableFuture.supplyAsync(() -> fetchUser())
.thenApply(user -> fetchOrder(user.getId()))
.thenAccept(order -> System.out.println("Order: " + order))
.exceptionally(ex -> {
System.err.println("Error: " + ex.getMessage());
return null;
});