package com.starit.open.main;
import java.util.ArrayList;
import java.util.List;
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;
/**
*
* @author wenin819
*
* Callable 和 Future接口
* Callable是类似于Runnable的接口,实现Callable接口的类和实现Runnable的类都是可被其它线程执行的任务。
* Callable和Runnable有几点不同:
* (1)Callable规定的方法是call(),而Runnable规定的方法是run().
* (2)Callable的任务执行后可返回值,而Runnable的任务是不能返回值的。
* (3)call()方法可抛出异常,而run()方法是不能抛出异常的。
* (4)运行Callable任务可拿到一个Future对象,
* Future 表示异步计算的结果。它提供了检查计算是否完成的方法,以等待计算的完成,并检索计算的结果。
* 通过Future对象可了解任务执行情况,可取消任务的执行,还可获取任务执行的结果。
*
*/
public class CallableThreadSync implements Runnable{
private static final ExecutorService es = Executors.newFixedThreadPool(5);
public static class ItemThread implements Callable<Integer> {
public int addNum;
public ItemThread(int addNum) {
this.addNum = addNum;
}
@Override
public Integer call() {
try {
Thread.sleep(addNum * 1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return addNum * 2;
}
}
public static void main(String[] args) {
CallableThreadSync test = new CallableThreadSync();
long startTime = System.currentTimeMillis();
new Thread(test, "thread1").start();
new Thread(test, "thread2").start();
long endTime = System.currentTimeMillis();
System.out.println("main:用时" + (endTime - startTime) / 1000 + "秒");
}
public void run() {
long startTime = System.currentTimeMillis();
List<ItemThread> itemThreads = new ArrayList<CallableThreadSync.ItemThread>(3);
ItemThread itemThread = null;
for(int i = 0; i < 3; i++) {
itemThread = new ItemThread(i + 1);
itemThreads.add(itemThread);
}
List<Future<Integer>> futureList = null;
try {
futureList = es.invokeAll(itemThreads);
} catch (InterruptedException e1) {
e1.printStackTrace();
}
Integer result = 1;
for(Future<Integer> future : futureList) {
try {
result += future.get();
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
}
}
String infoMsg = Thread.currentThread().getName() + ":";
long endTime = System.currentTimeMillis();
System.out.println(infoMsg + result + "(用时" + (endTime - startTime) / 1000 + "秒)");
}
@Override
protected void finalize() throws Throwable {
es.shutdownNow();
super.finalize();
}
}