Future接口定义异步任务状态查询与结果获取契约,实际获取结果需通过实现类(如FutureTask)的get()方法——该操作阻塞且须处理ExecutionException(其cause为任务真实异常)、InterruptedException或TimeoutException;isDone()和isCancelled()用于非阻塞状态检查;cancel(true)尝试中断任务线程,效果依赖任务是否响应中断;CompletableFuture是现代化替代方案,支持链式调用、组合编排与回调处理,推荐优先使用。

Future接口本身不直接提供“获取结果”的能力,而是定义了异步任务的状态查询和结果获取契约。真正获取结果靠的是它的实现类(如FutureTask)配合get()方法——但这个操作是阻塞的,且需正确处理异常和超时。
get()方法:阻塞式取结果,必须处理异常
调用future.get()会一直等待任务完成,直到返回结果或抛出异常。它有两种常用重载:
- get():无限期等待,一旦任务被取消、执行异常或线程中断,会分别抛出CancellationException、ExecutionException、InterruptedException
- get(long timeout, TimeUnit unit):带超时的等待,超时未完成则抛出TimeoutException,更安全,推荐在生产环境使用
注意:ExecutionException的cause才是你任务里实际抛出的异常(比如NullPointerException),记得用getCause()提取。
isDone()和isCancelled():非阻塞状态检查
在不确定任务是否完成时,别急着get()。先用这两个方法判断:
立即学习“Java免费学习笔记(深入)”;
- isDone():任务已结束(无论正常完成、异常终止还是被取消)就返回true
- isCancelled():任务是否在运行前就被cancel(true)取消了
适合做轮询或条件分支,比如“如果已完成就取结果,否则记录日志并稍后重试”。
cancel()与中断:主动终止任务的注意事项
future.cancel(true)尝试中断正在执行的任务线程,但效果取决于任务代码是否响应中断:
- 若任务内部有Thread.sleep()、wait()、BlockingQueue.take()等可中断阻塞调用,会立即抛出InterruptedException
- 若任务纯CPU计算且没检测Thread.interrupted(),cancel()无法真正停止它,只是把Future状态设为“已取消”,后续get()仍会抛CancellationException
所以写异步任务时,建议定期检查中断状态,配合return或break提前退出。
CompletableFuture:Future的现代化替代方案
原生Future功能有限(不能链式调用、无法组合、无回调支持)。Java 8引入CompletableFuture,它实现了Future接口,同时支持:
- thenApply/thenAccept/thenRun:任务完成后的同步/异步处理
- thenCompose/thenCombine:多个Future串行或并行编排
- exceptionally/handle:统一异常处理,避免层层try-catch
- complete()/completeExceptionally():手动完成Future,便于测试或桥接非Executor任务
日常开发中,优先用CompletableFuture代替原始Future,尤其涉及多任务协作或需要非阻塞响应逻辑时。
Future不是万能容器,它只管“有没有结果”;真正让异步变实用的,是合理搭配状态判断、超时控制、异常解包,以及适时升级到CompletableFuture。










