一、基本概述
CompletableFuture代表一个异步计算的结果,这个结果可以是已完成、正在进行或尚未开始的状态。它提供了一种灵活且类型安全的方式来表达异步操作的生命周期,包括创建、组合、处理结果以及处理异常。其设计灵感来源于函数式编程中的Promises/Futures模式,旨在简化异步编程模型,提高代码的可读性和可维护性。
二、创建方式
- 手动创建:通过
new CompletableFuture<>()
创建一个空的CompletableFuture对象,然后可以在其他地方手动完成它,例如使用complete(T value)
方法。 - supplyAsync:该方法接收一个
Supplier
函数式接口,并异步执行它,然后返回包含其结果的CompletableFuture。可以使用默认的线程池(ForkJoinPool.commonPool()),也可以指定一个自定义的线程池。 - runAsync:与supplyAsync类似,但runAsync接收的是一个
Runnable
,它不返回任何结果。
三、链式调用
CompletableFuture支持链式调用,可以在一个任务完成后指定一系列的操作。这些操作可以是同步的,也可以是异步的。常见的链式调用方法包括:
- thenApply:在当前任务执行完成后,执行一个函数来处理返回值,并返回一个新的CompletableFuture。
- thenAccept:在当前任务执行完成后,获取结果并执行一个消费者函数,但不返回新的CompletableFuture(返回类型为
CompletableFuture<Void>
)。 - thenRun:在当前任务执行完成后,执行一个无参数的动作,不返回新的CompletableFuture(返回类型为
CompletableFuture<Void>
)。 - thenCompose和thenCombine:允许将多个CompletableFuture组合在一起,以某种方式处理它们的结果。
四、异常处理
CompletableFuture提供了对异常的处理能力,可以在异步操作出错时进行异常捕获和处理。常见的异常处理方法包括:
- exceptionally:当当前CompletableFuture因异常而未能正常完成时,应用给定的Function处理异常,并返回一个新的CompletableFuture,