java使用线程池和Future接口实现异步的实例

线程池可以提供线程的复用和管理,避免线程频繁创建和销毁的开销。而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接口是一个可靠的方式来实现异步操作。

猜你喜欢

转载自blog.csdn.net/worldkingpan/article/details/129717537