/**
* 书本:《Thinking In Java》
* 功能:在线程运行中返回得到相应的返回值
* 文件:CallableDemo.java
* 时间:2015年5月7日14:52:11
* 作者:cutter_point
*/
package Lesson21Concurency;
import java.util.ArrayList;
import java.util.concurrent.Callable;
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;
}
@Override
public String call() throws Exception //这个是必要实现的接口
{
return "result of TaskWithResult " + id;
}
}
public class CallableDemo
{
public static void main(String[] args)
{
ExecutorService exec = Executors.newCachedThreadPool(); //新建进程连接池
ArrayList<Future<String>> results = new ArrayList<Future<String>>(); //Future 表示异步计算的结果
//循环启动几个线程
for(int i = 0; i < 10; ++i)
{
//submit(Callable<?> ) 表示提交一个返回值的任务用于执行,返回一个表示任务的未决结果的 Future。
results.add(exec.submit(new TaskWithResult(i)));
}
//吧线程执行的结果显示出来
for(Future<String> fs : results)
{
try
{
//获取Futrue中线程返回值 V get() 如有必要,等待计算完成,然后获取其结果。
System.out.println(fs.get());
}
catch (Exception e)
{
System.out.println(e);
}
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