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<FutureTask<Integer>> taskList = new ArrayList<FutureTask<Integer>>();
// 创建线程池
ExecutorService exec = Executors.newFixedThreadPool(5);
for (int i = 0; i < 10; i++) {
// 传入Callable对象创建FutureTask对象
FutureTask<Integer> ft = new FutureTask<Integer>(thread_Pool_FutureTask_MutiCompute.n