线程池可以提供线程的复用和管理,避免线程频繁创建和销毁的开销。而Future接口则可以获取异步任务的执行结果和状态,避免了阻塞等待异步任务完成的情况。 下面是一个简单的示例代码: ``` import java.util.concurrent.*; public class AsyncExample { public static void main(String[] args) throws InterruptedException, ExecutionException { // 创建线程池 ExecutorService executor = Executors.newFixedThreadPool(2); // 提交异步任务 Future<String> future1 = executor.submit(new Task("Task 1")); Future<String> future2 = executor.submit(new Task("Task 2")); // 获取异步任务结果 String result1 = future1.get(); String result2 = future2.get(); // 输出结果 System.out.println(result1); System.out.println(result2); // 关闭线程池 executor.shutdown(); } static class Task implements Callable<String> { private final String name; public Task(String name) { this.name = name; } @Override public String call() throws Exception { // 模拟耗时操作 Thread.sleep(1000); return "Result of " + name; } } } ``` 在这个示例中,我们创建了一个固定大小的线程池,并提交了两个异步任务。每个异步任务都是一个实现了Callable接口的类,可以在call()方法中执行耗时操作,并返回结果。 我们使用Future接口获取异步任务的结果,并在主线程中输出。最后,我们关闭了线程池。 这个示例代码只是一个简单的例子,实际应用中可能需要更复杂的异步操作和任务调度。但是使用线程池和Future接口是一个可靠的方式来实现异步操作。