日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java8 CompletableFuture异步编程

發布時間:2025/7/14 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java8 CompletableFuture异步编程 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Future 接口的局限性

Future接口可以構建異步應用,但依然有其局限性。它很難直接表述多個Future 結果之間的依賴性。實際開發中,我們經常需要達成以下目的:

將兩個異步計算合并為一個——這兩個異步計算之間相互獨立,同時第二個又依賴于第一個的結果。
等待 Future 集合中的所有任務都完成。
僅等待 Future集合中最快結束的任務完成(有可能因為它們試圖通過不同的方式計算同一個值),并返回它的結果。
通過編程方式完成一個Future任務的執行(即以手工設定異步操作結果的方式)。
應對 Future 的完成事件(即當 Future 的完成事件發生時會收到通知,并能使用 Future 計算的結果進行下一步的操作,不只是簡單地阻塞等待操作的結果)

新的CompletableFuture類將使得這些成為可能。
CompletableFuture

JDK1.8才新加入的一個實現類CompletableFuture,實現了Future<T>, CompletionStage<T>兩個接口。

當一個Future可能需要顯示地完成時,使用CompletionStage接口去支持完成時觸發的函數和操作。

當兩個及以上線程同時嘗試完成、異常完成、取消一個CompletableFuture時,只有一個能成功。

CompletableFuture實現了CompletionStage接口的如下策略:

1、為了完成當前的CompletableFuture接口或者其他完成方法的回調函數的線程,提供了非異步的完成操作。

2、沒有顯式入參Executor的所有async方法都使用ForkJoinPool.commonPool()為了簡化監視、調試和跟蹤,所有生成的異步任務都是標記接口AsynchronousCompletionTask的實例。

3、所有的CompletionStage方法都是獨立于其他共有方法實現的,因此一個方法的行為不會受到子類中其他方法的覆蓋。

CompletableFuture實現了Futurre接口的如下策略:

1、CompletableFuture無法直接控制完成,所以cancel操作被視為是另一種異常完成形式。方法isCompletedExceptionally可以用來確定一個CompletableFuture是否以任何異常的方式完成。

2、以一個CompletionException為例,方法get()和get(long,TimeUnit)拋出一個ExecutionException,對應CompletionException。為了在大多數上下文中簡化用法,這個類還定義了方法join()和getNow,而不是直接在這些情況中直接拋出CompletionException。

CompletableFuture中4個異步執行任務靜態方法:

public static <U> CompletableFuture<U> supplyAsync(Supplier<U> supplier) {

  return asyncSupplyStage(asyncPool, supplier);
}

public static <U> CompletableFuture<U> supplyAsync(Supplier<U> supplier,Executor executor) {

  return asyncSupplyStage(screenExecutor(executor), supplier);
}

public static CompletableFuture<Void> runAsync(Runnable runnable) {

  return asyncRunStage(asyncPool, runnable);
}

public static CompletableFuture<Void> runAsync(Runnable runnable, Executor executor) {

  return asyncRunStage(screenExecutor(executor), runnable);
}

?其中supplyAsync用于有返回值的任務,runAsync則用于沒有返回值的任務。Executor參數可以手動指定線程池,否則默認ForkJoinPool.commonPool()系統級公共線程池,?

轉載于:https://www.cnblogs.com/leizhuang/p/9968370.html

總結

以上是生活随笔為你收集整理的java8 CompletableFuture异步编程的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。