Java1.6多線程之同步方法
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();
}
}
最後更新:2017-04-04 07:03:11