1、概念
Future表示一個可能還沒有完成的非同步任務的結果,針對這個結果可以加入Callback以便在任務執行成功或失敗後作出相應的操作。
2、Future介面
Future介面定義了主要的5個介面方法,有RunnableFuture和SchedualFuture繼承這個接口,以及CompleteFuture和ForkJoinTask繼承這個介面。
3、實例
package test; import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.FutureTask; public class CallableFutureTest { public static void main(String[] args) { long startTime = System.currentTimeMillis(); Callable<Integer> calculateCallable = new Callable<Integer>() { @Override public Integer call() throws Exception { // TODO Auto-generated method stub Thread.sleep(2000);//模擬耗時時間int result = 1+2; return result; } }; FutureTask<Integer> calculateFutureTask = new FutureTask<>(calculateCallable); Thread t1 = new Thread(calculateFutureTask); t1.start(); //現在加入Thread運行的是一個模擬遠端呼叫耗時的服務,並且依賴他的計算結果(例如網路計算器) try { //模擬耗時任務,主執行緒做自己的事情,體現多執行緒的優勢Thread.sleep(3000); int a = 3+5; Integer result = calculateFutureTask.get(); System.out.println("result = "+(a+result));//模擬主執行緒依賴子執行緒的執行結果long endTime = System.currentTimeMillis(); System.out.println("time = "+(endTime-startTime)+"ms"); } catch (InterruptedException | ExecutionException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
從上面可以看到上面耗時大概是3s,其實主要就是主執行緒sleep(3000)所耗費的時間,如果不使用Future,並且依賴執行緒的結果,我們可能需要的時間可能是需要5s (子執行緒2s+主線程3s)。
以上就是Future在java中取得執行緒結果的方法,可以說Future在處理執行緒上比較靈活,機制大致為進行一個執行緒時,另一個執行緒同時運作。大家有興趣的話,可以在課後深入了解。