Future是代表尚未完成但将来可能完成的异步计算结果的占位符,核心功能为获取结果(get())、查询状态(isDone/isCancelled)和控制执行(cancel);它无回调、不支持链式组合,新项目推荐使用CompletableFuture。

Future 在 Java 中是一个“结果占位符”,它不执行任务,也不代表线程本身,而是代表一个**尚未完成但将来可能完成的异步计算结果**。它的核心作用就三点:拿到结果、查状态、控执行。
获取异步任务的返回值
提交 Callable 任务后,ExecutorService 返回一个 Future 对象。调用 get() 才真正取值——如果任务已完成,立刻返回;如果还没完,主线程会阻塞等待。生产环境建议用带超时的版本:
- future.get():无限等待,风险高,容易卡死
- future.get(3, TimeUnit.SECONDS):最多等 3 秒,超时抛 TimeoutException,更安全
非阻塞地检查任务状态
不想干等?可以用这些方法提前感知进度:
- isDone():返回 true 表示任务已结束(无论成功、失败或被取消)
- isCancelled():只在 cancel() 被调用且生效后返回 true
- 配合轮询或条件逻辑使用,比如“每 200ms 查一次,最多试 5 次”
主动干预任务生命周期
Future 提供了有限但关键的控制能力:
立即学习“Java免费学习笔记(深入)”;
- cancel(true):尝试中断正在运行的任务线程(是否生效取决于任务内部是否响应中断)
- cancel(false):只取消未启动的任务,对已运行的无效
- 注意:一旦 isDone() 为 true,cancel 就不再起作用
Future 的定位和局限
它本质是 JDK 5 引入的基础契约接口,设计目标是轻量、通用。但因此也带来明显短板:
- 没有回调机制:不能“任务一完成就自动触发后续操作”
- 不能链式组合:多个 Future 难以串并协调
- 异常处理被动:必须显式 catch ExecutionException 并 unwrap cause
- 新项目推荐直接用 CompletableFuture —— 它兼容 Future,又补全了所有缺失能力










