Callable与 Future 两功能是Java 5版本中加入的,Callable是相似于Runnable的接口,实现Callable接口的类和实现Runnable的类。php
Callable的接口定义以下:java
public interface Callable<V> { /** * Computes a result, or throws an exception if unable to do so. * * @return computed result * @throws Exception if unable to compute a result */ V call() throws Exception; }
Callable和Runnable的区别以下:dom
Callable定义的方法是call,而Runnable定义的方法是run。异步
Callable的call方法能够有返回值,而Runnable的run方法不能有返回值。spa
Callable的call方法可抛出异常,而Runnable的run方法不能抛出异常。code
Future定义orm
Future表示异步计算的结果,它提供了检查计算是否完成的方法,以等待计算的完成,并检索计算的结果。Future的cancel方法能够取消任务的执行,它有一布尔参数,参数为 true 表示当即中断任务的执行,参数为 false 表示容许正在运行的任务运行完成。Future的 get 方法等待计算完成,获取计算结果。接口
下面的示例中,咱们使用Callable来提交任务,使用Future来获得执行的结果。get
public interface Future<V> {
boolean cancel(boolean mayInterruptIfRunning);
boolean isCancelled(); boolean isDone(); V get() throws InterruptedException, ExecutionException; V get(long timeout, TimeUnit unit) throws InterruptedException, ExecutionException, TimeoutException;
import java.util.ArrayList; import java.util.Date; import java.util.Iterator; import java.util.Random; import java.util.concurrent.Callable; import java.util.concurrent.CompletionService; import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutorCompletionService; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Future; public class Test { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub ExecutorService threadPool = Executors.newSingleThreadExecutor(); Future<String> future = threadPool.submit(new Callable<String>() { public String call() throws Exception { Thread.sleep(2000); return "Hello"; }; }); System.out.println("Wait for result..."); try { System.out.println("Get the result:" + future.get()); } catch (InterruptedException e) { e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } threadPool.shutdown(); } }
运行结果:
Wait for result...
Get the result:Hello
it