亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java CompletableFuture的使用詳解

 更新時間:2021年03月10日 09:00:07   作者:Mirrors  
這篇文章主要介紹了Java CompletableFuture的使用詳解,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下

CompletableFuture​

它代表某個同步或異步計算的一個階段。你可以把它理解為是一個為了產(chǎn)生有價值最終結果的計算的流水線上的一個單元。這意味著多個指令可以鏈接起來從而一個階段的完成可以觸發(fā)下一個階段的執(zhí)行。

任務開啟

supplyAsync 開啟一個子線程去執(zhí)行有返回結果

開啟一個子線程用來執(zhí)行執(zhí)行事務,可以通過返回值的join來得到返回值.

例如:

print("去煮飯了");
CompletableFuture<String> completableFuture = CompletableFuture.supplyAsync(() -> {
 print("煮飯中....");
 sleep();
 sleep();
 sleep();
 print("煮飯完成");
 return "盛米飯";
});
sleep();
print("炒完菜了");
sleep();
print(completableFuture.join()+"!開吃");

返回結果:

runAsync 開啟一個子線程去執(zhí)行無結果

任務結束

get\join 獲得返回值

join 隱性拋出異常、get顯性拋出異常

Stopwatch stopwatch = Stopwatch.createStarted();
CompletableFuture<Integer> future1 = CompletableFuture.supplyAsync(() -> 16 / 2);
CompletableFuture<Integer> future2 = CompletableFuture.supplyAsync(() -> 27 / 3);
try {
 Assertions.assertEquals(future1.get(),8);
} catch (InterruptedException e) {
 e.printStackTrace();
} catch (ExecutionException e) {
 e.printStackTrace();
}
Assertions.assertEquals(future2.join(),9);

串行任務

thenApply\thenApplyAsync 串行將異步結果進行同步\異步的處理

​ 在當前階段正常執(zhí)行完成后(正常執(zhí)行是指沒有拋出異常)對前者的結果進行的操作。

CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> 16 / 2).thenApply(t1 -> t1*2);
Assertions.assertEquals(future.join(),16);

handle\handleAsync 允許有異常的情況下任然進行異步任務執(zhí)行

handle方法和 thenApply方法處理方式基本一樣。不同的是 handle是在任務完成后再執(zhí)行,還可以處理異常的任務。thenApply只可以執(zhí)行正常的任務,任務出現(xiàn)異常則不執(zhí)行 thenApply方法。

CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> 16 / 0).handle((t1, e) -> {
 System.out.println("handle=" + e.getMessage());
 return Integer.MAX_VALUE;
});
Assertions.assertEquals(future.join(),Integer.MAX_VALUE);

thenAccept\thenAcceptAsync 同步\異步穿行消費前任務無返回結果

CompletableFuture<Void> future = CompletableFuture.supplyAsync(() -> getRemoteUser(familyName))
	.thenAccept(list -> list.forEach(System.out::println));
System.out.println(String.format("總執(zhí)行耗時[%d]毫秒", stopwatch.elapsed(TimeUnit.MILLISECONDS)));
future.join();

thenRun\thenRunAsync 不關注前任務的執(zhí)行結果

不關心任務的處理結果。只要上面的任務正確的執(zhí)行完成,就開始執(zhí)行。同樣其也無返回值

 CompletableFuture future = CompletableFuture.supplyAsync(() -> 12 / 1).thenRun(() -> System.out.println("無返回值的執(zhí)行"));
 System.out.println(future.join());

thenCompose\thenComposeAsync 允許多個任務Future流水線執(zhí)行

​ 允許你對兩個任務進行流水線操作,第一個操作完成時,將其結果作為參數(shù)傳遞給第二個操作。你可以將多個任務嵌套的進行見例2

例1:

print("去煮飯了");
CompletableFuture<String> completableFuture = CompletableFuture.supplyAsync(() -> {
 print("煮飯中....");
 sleep();
 sleep();
 print("煮飯完成");
 return "米飯";
}).thenCompose(rice -> CompletableFuture.supplyAsync(() ->{
 print("洗碗");
 sleep();
 print("洗碗洗完了");
 return rice+"盛好了";
}));
sleep();
print("炒完菜了");
print(completableFuture.join()+"!開吃");

返回結果:

例2:

CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> 16 / 2)
 .thenComposeAsync(t1 -> CompletableFuture.supplyAsync(() -> t1 / 2)
   .thenComposeAsync(t2 -> CompletableFuture.supplyAsync(() -> t2 / 2)));
Assertions.assertEquals(future.join(),2);

結論:可以看出supplyAsync執(zhí)行了異步方法,thenCompose將上一個異步的結果(文中的rice)拿到以后通過一個線程去執(zhí)行了當前異步任務,并將結果在future.join()中輸出了。

whenComplete\whenCompleteAsync 串行將異步結果進行同步\異步的處理

​ 與thenAccept很像,區(qū)別在于whenComplete的執(zhí)行會將前任務的返回結果給返回而thenAccept無返回結果。

//whenComplete
CompletableFuture<Integer> future1 = CompletableFuture.supplyAsync(() -> 16 / 2);
CompletableFuture<Integer> future = future1.whenComplete((t1, e) -> {
 Assertions.assertEquals(Thread.currentThread().getName(),"main");
 Assertions.assertEquals(t1, 8);
 Assertions.assertNull(e);
 t1 = 10;
});
Assertions.assertEquals(future.join(), 8);
//thenAccept
CompletableFuture<Integer> future2 = CompletableFuture.supplyAsync(() -> 16 / 2);
CompletableFuture<Void> future3 = future2.thenAccept(t1 -> {
 Assertions.assertEquals(Thread.currentThread().getName(), "main");
 Assertions.assertEquals(t1, 8);
});
Assertions.assertNull(future3.join());
//thenApply
CompletableFuture<Integer> future4 = CompletableFuture.supplyAsync(() -> 16 / 2);
CompletableFuture<Integer> future5 = future4.thenApply(t1 -> {
 Assertions.assertEquals(Thread.currentThread().getName(), "main");
 Assertions.assertEquals(t1, 8);
 return t1*2;
});
Assertions.assertEquals(future5.join(),16);
System.out.println("------OK-------");

并行任務

thenCombine 并列多任務執(zhí)行并結果匯總​

同時執(zhí)行兩個異步任務,并且在最后通過BiFunction將兩個結果綜合起來進行結果輸出.

例如:

print("去煮飯了");
CompletableFuture<String> completableFuture = CompletableFuture.supplyAsync(() -> {
 print("煮飯中....");
 sleep();
 sleep();
 print("煮飯完成");
 return "米飯";
}).thenCombine(CompletableFuture.supplyAsync(() ->{
 print("洗碗");
 sleep();
 print("洗碗洗完了");
 return "碗好了";
}),(rice,bowl) -> {
 print("盛個飯");
 return "盛個飯";
});
sleep();
print("炒完菜了");
print(completableFuture.join()+"!開吃");

返回結果:

結論:可以看出supplyAsync執(zhí)行了異步方法,thenCombine又起了一個新的線程并把兩者的結果綜合到一起(rice/bowl),由BiFunction進行計算,并將結果在future.join()中輸出了。

thenAcceptBoth\thenAcceptBothAsync 并列多任務執(zhí)行并消費結果無返回值

thenCombine差不多,區(qū)別是thenAcceptBoth無返回值

CompletableFuture<Integer> future1 = CompletableFuture.supplyAsync(() -> 16 / 2).thenApply(t1 -> t1/2);
CompletableFuture<Integer> future2 = CompletableFuture.supplyAsync(() -> 27 / 3).thenApply(t1 -> t1/3);
CompletableFuture<Void> completableFuture = future1.thenAcceptBoth(future2, (t1, t2) -> {
 Assertions.assertEquals(t1 + t2, 7);
});
completableFuture.join();

applyToEither\applyToEitherAsync 兩個任務并行進行用快的那個的結果作為后續(xù)處理

​ 兩個任務,誰執(zhí)行返回的結果快,我就用那個任務的結果進行下一步的操作。

Stopwatch stopwatch = Stopwatch.createStarted();
CompletableFuture<Integer> future1 = CompletableFuture.supplyAsync(() -> {
 sleep(Integer.MAX_VALUE);
 return 16 / 2;
});
CompletableFuture<Integer> future2 = CompletableFuture.supplyAsync(() -> 27 / 3);
CompletableFuture<Integer> future = future1.applyToEither(future2, t -> t);
Assertions.assertEquals(future.join(),9);
Assertions.assertTrue(stopwatch.elapsed(TimeUnit.MILLISECONDS) < 1000);

runAfterBoth/runAfterBothAsync 兩個任務都完成了不關注執(zhí)行結果的進行下一步操作

Stopwatch stopwatch = Stopwatch.createStarted();
CompletableFuture<Integer> future1 = CompletableFuture.supplyAsync(() -> {
 sleep(2000);
 return 16 / 2;
});
CompletableFuture<Integer> future2 = CompletableFuture.supplyAsync(() -> 27 / 3);
CompletableFuture<Void> future = future1.runAfterBothAsync(future2,() -> System.out.println("1234"));
future.join();
Assertions.assertTrue(stopwatch.elapsed(TimeUnit.MILLISECONDS) > 2000);

以上就是Java CompletableFuture的使用詳解的詳細內(nèi)容,更多關于Java CompletableFuture的資料請關注腳本之家其它相關文章!

相關文章

  • Eclipse搭建spring開發(fā)環(huán)境圖文教程(推薦)

    Eclipse搭建spring開發(fā)環(huán)境圖文教程(推薦)

    下面小編就為大家?guī)硪黄狤clipse搭建spring開發(fā)環(huán)境圖文教程(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • Java游戲開發(fā)之俄羅斯方塊的實現(xiàn)

    Java游戲開發(fā)之俄羅斯方塊的實現(xiàn)

    俄羅斯方塊是一個最初由阿列克謝帕吉特諾夫在蘇聯(lián)設計和編程的益智類視頻游戲。本文和大家分享了利用Java語言實現(xiàn)這一經(jīng)典的小游戲的示例代碼,需要的可以參考一下
    2022-05-05
  • Java設計模式之單例模式實例詳解【懶漢式與餓漢式】

    Java設計模式之單例模式實例詳解【懶漢式與餓漢式】

    這篇文章主要介紹了Java設計模式之單例模式,簡單說明了單例模式的原理并結合具體實例形式分析了單例模式中懶漢式與餓漢式的具體實現(xiàn)與使用技巧,需要的朋友可以參考下
    2017-09-09
  • Spring IOC 三種配置方式詳解

    Spring IOC 三種配置方式詳解

    這篇文章主要介紹了Spring IOC 三種配置方式,基于xml配置方式組件管理,基于注解方式管理和配置類方式管理,這三種方式,通過圖文講解的非常詳細,需要的朋友可以參考下
    2024-05-05
  • java旋轉二維數(shù)組實例

    java旋轉二維數(shù)組實例

    這篇文章主要介紹了java旋轉二維數(shù)組,以實例形式較為詳細的講述了旋轉二維數(shù)的原理與實現(xiàn)方法,需要的朋友可以參考下
    2014-10-10
  • Java 面試題和答案 - (下)

    Java 面試題和答案 - (下)

    本文主要介紹Java 面試題,這里整理了Java面試題關于JDBC,線程異常處理,Servlet,JSP的知識的整理,幫助大家理解知識點,便于面試,有興趣的小伙伴可以參考下
    2016-09-09
  • 淺談SpringMVC請求映射handler源碼解讀

    淺談SpringMVC請求映射handler源碼解讀

    這篇文章主要介紹了淺談SpringMVC請求映射handler源碼解讀,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • Java視頻斷點上傳的實現(xiàn)示例

    Java視頻斷點上傳的實現(xiàn)示例

    斷點續(xù)傳指的是在下載或上傳時,將下載或上傳任務人為的劃分為幾個部分,本文主要介紹了Java視頻斷點上傳的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2024-05-05
  • MyEclipse到期破解代碼分享

    MyEclipse到期破解代碼分享

    前幾天有個小伙伴咨詢,使用的時候一直說myeclipse已過期,需要購買,如何解決?可以去網(wǎng)上搜搜注冊碼,但作為程序猿這么做簡直太無趣,看看我們自己來解決這個問題
    2014-11-11
  • @Autowired 自動注入接口失敗的原因及解決

    @Autowired 自動注入接口失敗的原因及解決

    這篇文章主要介紹了@Autowired 自動注入接口失敗的原因及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02

最新評論