Callable类
Runnable封装一个异步运行的任务,可以把它想象成为一个没有参数和返回值的异步方法。Callable与Runnable类似,但是有返回值。Callable接口是一个参数化的类型,只有一个方法call。
public interface Callable<E>{
E call() throws Exception;
}
类型参数是返回值的类型。例如,Callable表示一个最终返回Integer对象的异步计算。
Future类
Future保存异步计算的结果。可以启动一个计算,将Future对象交给某个线程,然后忘掉它。Future对象的所有者在结果计算好之后就可以获得它。
public interface Future<E>{
E get() throws ...;
E get(long timeout, TimeUnit unit) throws ...;
void cancel(boolean mayInterrupt);
boolean isCancelled();
boolean isDone();
}
第一个get方法的调用被阻塞,直到计算完成。如果在计算完成之前,第二个方法的调用超时,抛出一个TimeoutException异常。如果运行该计算的线程被中断,两个方法都将抛出Inter ruptedException。如果计算已经完成,那么get方法立即返回。
如果计算还在进行,isDone方法返回false;如果完成了,则返回true。
可以用cancel方法取消该计算。如果计算还没有开始,它被取消且不再开始。如果计算处于运行之中,那么如果MayInterrupt参数为true,它就被中断。
FutureTask类
FutrueTask包装器是一种非常便利的机制,可将Callable转换成Future和Runnable,它同时实现二者的接口。例如:
Callable<Integer> myCompution = ...;
FutureTask<Integer> task = new FutureTask<Integer>(myCompution);
Thread t = new Thread(task);//这是一个Runnable
t.start();
...
Integer result = task.get();//这是一个Future