FutureTask表示的计算是通过Callable来实现的,相当于一种可生成结果的Runnable,并且可以处于以下三种状态:等待运行,正在运行,运行结束。执行完成表示所有可能的结束方式,包括正常结束,由于取消而结束和由于异常而结束等。当FutureTask进入完成状态后,它会永远停在这个状态上。
FutureTask.get的行为取决于任务的状态。如果任务已经完成,那么get会立即返回结果,否则get方法会一直阻塞,直到任务进入完成状态。FutureTask将计算结果从执行计算的线程的结果传递到另一个线程。而FutureTask的规范保证了这个过程的安全性。
FutureTask在Executor框架中表示异步任务,此外还可以用来表示一些时间较长的计算,这些计算可以在使用计算结果之前启动。下面有一个demo,使用FutureTask来减少等待时间的例子。
package com.wsy.thread;
import java.util.Date;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
public class FutureTaskDemo {
public static void main(String[] args) {
ExecutorService pool = Executors.newFixedThreadPool(10);
Future<String> future = pool.submit(new Callable<String>(){
@Override
public String call() throws Exception {
System.out.println(new Date(System.currentTimeMillis()));
Thread.sleep(2000);
System.out.println(new Date(System.currentTimeMillis()));
return "123";
}
});
try {
System.out.println(future.get());
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
}
}
}
提前将获取结果的过程交给一个线程处理,当需要使用该结果的时候,该结果已经计算好了。这个在实际开发当中也是有所应用的,假设你需要查询一个信息,这个信息的一部分结果是需要从其他接口查询的。当我们需要查询的时候,可以将不同的数据,通过不同的线程进行查询,将查询结果存储在FutureTask当中。当需要使用的时候就可以直接使用了。