import java.util.ArrayList;
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;
class TaskWithResult implements Callable<String> {
private int id;
public TaskWithResult(int id ) {
this.id = id;
}
public String call() {
return "result of TaskwithResult " + id;
}
}
public class CallableDemo {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
ExecutorService exec = Executors.newCachedThreadPool();
ArrayList<Future<String>> results = new ArrayList<Future<String>>();
for(int i=0; i<10; i++) {
results.add(exec.submit(new TaskWithResult(i)));
}
for(Future<String> fs : results) {
try{
System.out.println(fs.get());
} catch(InterruptedException e) {
e.printStackTrace();
} catch(ExecutionException e) {
e.printStackTrace();
} finally {
exec.shutdown();
}
}
}
}
结果:
result of TaskwithResult 0
result of TaskwithResult 1
result of TaskwithResult 2
result of TaskwithResult 3
result of TaskwithResult 4
result of TaskwithResult 5
result of TaskwithResult 6
result of TaskwithResult 7
result of TaskwithResult 8
result of TaskwithResult 9
1、接口:java.util.concurrent.Callable<V>只有一个方法,不是run(),而是call(),它有返回值,类型为V。
2、ExecutorService的submit方法会返回Future<String>对象。
3、你可以用isDone()方法来查询Future是否已经完成。当任务完成时它具有一个结果,你可以调用get()方法来获取该结果。你也可以不用isDone()进行检查就直接调用get(),这种情况下get()将阻塞,直至结果准备就绪。你还可以在试图调用get()来获取结果之前,先调用具有超时的get()或者调用isDone()来查看任务是否完成。get()返回类型为V,即call方法的返回值!!
4、get()方法会抛出InterruptedException和ExecutionException。