线程池可以提供线程的复用和管理,避免线程频繁创建和销毁的开销。而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;}@Overridepublic String call() throws Exception {// 模拟耗时操作Thread.sleep(1000);return "Result of " + name;}}
}
```在这个示例中,我们创建了一个固定大小的线程池,并提交了两个异步任务。每个异步任务都是一个实现了Callable接口的类,可以在call()方法中执行耗时操作,并返回结果。我们使用Future接口获取异步任务的结果,并在主线程中输出。最后,我们关闭了线程池。这个示例代码只是一个简单的例子,实际应用中可能需要更复杂的异步操作和任务调度。但是使用线程池和Future接口是一个可靠的方式来实现异步操作。