FutureTask可用于异步获取执行结果或者取消执行任务的场景,通过传入Runnable或者Callable的任务给FutureTask,调用run()方法放入线程池,之后通过外部的FutureTask的get()方法获得结果。FutureTask主要用于非常耗时的计算。
1、执行多任务计算
利用FutureTask和ExecutorService,可以用多线程的方式提交计算任务,主线程继续执行其他任务,当主线程需要子线程的计算结果时,在异步获取子线程的执行结果。
代码如下:
public class Thread_Pool_FutureTask_MutiCompute {
public static void main(String args[]){
Thread_Pool_FutureTask_MutiCompute thread_Pool_FutureTask_MutiCompute=new Thread_Pool_FutureTask_MutiCompute();
// 创建任务集合
List> taskList = new ArrayList>();
// 创建线程池
ExecutorService exec = Executors.newFixedThreadPool(5);
for (int i = 0; i < 10; i++) {
// 传入Callable对象创建FutureTask对象
FutureTask ft = new FutureTask(thread_Pool_FutureTask_MutiCompute.new ComputeTask(i, "" + i));

本文介绍了Java中如何使用FutureTask进行异步任务执行,并通过ExecutorService提交任务到线程池。FutureTask允许主线程在不影响执行的同时,等待获取计算结果。通过示例展示了如何在多任务计算中应用FutureTask,以及在高并发环境下,利用FutureTask确保任务只执行一次,以优化性能。
最低0.47元/天 解锁文章
1426

被折叠的 条评论
为什么被折叠?



