package com;
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 Test {
/**
* @param args
*/
public static void main(String[] args) {
//创建一个线程池
ExecutorService pool = Executors.newFixedThreadPool(2);
//创建两个有返回值的任务
Callable c1 = new MyCallable("A");
Callable c2 = new MyCallable1("B");
//执行任务并获取Future对象
Future f1 = pool.submit(c1);
Future f2 = pool.submit(c2);
//从Future对象上获取任务的返回值,并输出到控制台
try {
System.out.println(">>>"+f1.get().toString());
System.out.println(">>>"+f2.get().toString());
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ExecutionException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//关闭线程池
pool.shutdown();
}
}
</pre><pre code_snippet_id="1749526" snippet_file_name="blog_20160707_4_9192511" name="code" class="java">
</pre><pre code_snippet_id="1749526" snippet_file_name="blog_20160707_5_414011" name="code" class="java"><pre name="code" class="java">package com;
import java.util.concurrent.Callable;
class MyCallable implements Callable{
private String oid;
MyCallable(String oid) {
this.oid = oid;
}
public Object call() throws Exception {
System.out.println(oid+"开始执行");
Thread.sleep(5000);
return oid+"任务返回的内容";
}
}
package com;
import java.util.concurrent.Callable;
class MyCallable1 implements Callable{
private String oid;
MyCallable1(String oid) {
this.oid = oid;
}
public Object call() throws Exception {
System.out.println(oid+"开始执行");
return oid+"任务返回的内容";
}
}
打印信息:
A开始执行
B开始执行
>>>A任务返回的内容
>>>B任务返回的内容