import java.util.concurrent.Callable; /** * Created by Administrator on 2017/9/1. */ public class TaskWithResult implements Callable<String> { private int id; public TaskWithResult(int id) { this.id = id; } @Override public String call() { return "result of TaskWithResult" + id; } }
import java.util.ArrayList; import java.util.concurrent.Exchanger; import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Future; /** * Created by Administrator on 2017/9/1. */ public class CallableDemo { public static void main(String[] args) { ExecutorService executorService = Executors.newCachedThreadPool(); ArrayList<Future<String>> results = new ArrayList<Future<String>>(); for (int i = 0; i < 10; i++) { results.add(executorService.submit(new TaskWithResult(i))); } for (Future<String> fs : results) { try { System.out.println(fs.get()); } catch (InterruptedException e) { e.printStackTrace(); return; } catch (ExecutionException e) { e.printStackTrace(); return; } finally { executorService.shutdown(); } } } }
运行结果:java
结论:Runnable是执行工做的独立任务,可是它不返回任何值。若是你但愿任务在完成时可以返回一个值,那么能够实现Callable接口而不是Runnable接口。在JAVA SE5中引入的Callabele接口而不是Runnable接口。ide
Callablel是一种具备类型参数的泛型,它的类型参数表示的是从方法call()(而不是run())中返回的值,而且必须使用ExecutorServiceSubmit()方法调用它。submit()方法会产生Future对象,它用Callable返回结果的特定类型进行了参数化。能够用isDone()方法来查询Future是否已经完成。当任务完成时,它具备一个结果,你能够调用get()方法来获取该结果。也能够不用isDone()进行检查就直接调用get(),在这种状况下,get()将阻塞,直至结果准备就绪。this