一、CompletableFuture是啥
Java 8 引入的CompletableFuture 類,支持 future 完成時觸發一些依賴的函數和動作
CompletableFuture 實現了 Future 以及 ComplatableStage 接口, 實現 Future 接口代表其本身可以作爲生產者和消費者的 “橋樑”, 而 ComplatableStage 接口定義了以上所有的組合條件。
完成條件,後置處理的多種類型衆多的 API, 可以說 Future 接口只是描述了單個任務處理的方式, 而 CompletableStage 接口更進一步的從實際的編程需求出發,滿足了多個任務協同處理的場景需求,包括多個任務任一完成或全部完成時。
任務串行順序執行, 並行執行,並且創造性的提出了 apply, accept, run 三種後置處理器的類型,本質上後置處理還是鏈式順序執行的。這樣在衆多子任務的場景需求中, CompletableFuture 可以很好的勝任
二、CompletableFuture調用實現異步
import java.util.concurrent.CompletableFuture;
public class CompletableFutureDemo {
public static void main(String[] args) throws Exception {
//同步,異步,異步回調
//同步
CompletableFuture<Void> completableFuture1 = CompletableFuture.runAsync(()->{
System.out.println(Thread.currentThread().getName()+"\t completableFuture1");
});
completableFuture1.get();
//異步回調
CompletableFuture<Integer> completableFuture2 = CompletableFuture.supplyAsync(()->{
System.out.println(Thread.currentThread().getName()+"\t completableFuture2");
int i = 10/0;
return 1024;
});
completableFuture2.whenComplete((t,u)->{
System.out.println("-------t="+t);
System.out.println("-------u="+u);
}).exceptionally(f->{
System.out.println("-----exception:"+f.getMessage());
return 444;
}).get();
}
}