Future是Java中用于获取异步任务结果的核心接口,通常与ExecutorService配合使用。首先创建线程池并提交Callable或Runnable任务,获得Future对象后可通过get()方法阻塞获取结果,或使用超时机制避免无限等待;还可通过isDone()判断任务是否完成、cancel()尝试取消任务。需注意get()的阻塞性,合理处理异常,并在使用后调用shutdown()关闭线程池。对于更复杂场景,推荐使用CompletableFuture以实现链式调用和回调功能。
在Java中,Future 是用于获取异步任务执行结果的核心接口。它通常与 ExecutorService 配合使用,提交任务后立即返回一个 Future 对象,后续可通过它来检查任务是否完成、获取结果或取消任务。
要使用 Future 获取异步任务结果,主要分为以下几步:
import java.util.concurrent.*;
public class FutureExample {
public static void main(String[] args) {
ExecutorService executor = Executors.newSingleThreadExecutor();
// 提交一个 Callable 任务
Future future = executor.submit(() -> {
Thread.sleep(2000);
return "任务执行完成";
});
System.out.println("任务已提交,正在执行...");
try {
// get() 会阻塞,直到任务
完成
String result = future.get();
System.out.println(result);
} catch (InterruptedException | ExecutionException e) {
e.printStackTrace();
} finally {
executor.shutdown();
}
}
}
Future 接口提供了几个重要方法来控制和查询任务状态:
try {
String result = future.get(3, TimeUnit.SECONDS);
System.out.println("结果:" + result);
} catch (TimeoutException e) {
System.out.println("任务超时,未在规定时间内完成");
future.cancel(true); // 取消任务
}
使用 Future 时需注意以下几点:
对于更复杂的异步场景,Java 8 引入了 CompletableFuture,支持链式调用和回调机制,比原始 Future 更灵活。
基本上就这些。Future 是理解 Java 异步编程的基础,掌握它有助于进一步学习 CompletableFuture 和响应式编程模型。