本週,我將深入研究 Java 的 CompletableFuture。
身為一名有前端背景的全端開發人員,處理非同步任務是我角色中不可避免的一部分——網路請求、後台運算等。在 Java 中,CompletableFuture 是一個強大的工具,用於處理這些任務,同時保持主執行緒回應。
Completable futures 之於 Java 就像 Promises 之於 JavaScript。
如果您熟悉 JavaScript,透過比較兩種語言可能有助於掌握這些概念。我喜歡將 CompletableFuture 視為 Java 版本的 Promise。它是一個表示非同步操作的最終結果的類,無論該結果是成功還是失敗。它作為 java.util.concurrent 套件的一部分在 Java 8 中引入,是一種編寫非阻塞程式碼的強大方法,具有連結操作和處理錯誤的方法,與 Promises 類似。
這是兩者的快速比較:
// JavaScript Promise fetchFromServer() .then(data => processData(data)) .then(result => updateUI(result)) .catch(error => handleError(error));
// Java CompletableFuture CompletableFuture.supplyAsync(() -> fetchDataFromServer()) .thenApply(data -> processData(data)) .thenAccept(result -> updateUI(result)) .exceptionally(error -> handleError(error));
如上所示,CompletableFuture 提供了類似的可連結語法,允許乾淨且可讀的非同步程式碼。
考慮一個場景,您需要從兩個單獨的端點取得使用者的個人資料資料和訂單歷史記錄。您可能希望避免在等待這些請求完成時凍結 UI。以下是使用 CompletableFuture 實現此功能的方法:
CompletableFuture<user> profileFuture = CompletableFuture.supplyAsync(() -> { // Fetch user profile from a service }); CompletableFuture<list>> ordersFuture = CompletableFuture.supplyAsync(() -> { // Fetch user orders from another service }); CompletableFuture<void> combinedFuture = CompletableFuture.allOf(profileFuture, ordersFuture); combinedFuture.thenRun(() -> { User user = userFuture.join(); List<order> orders = ordersFuture.join(); displayUserData(user, orders); }); </order></void></list></user>
在此範例中,我們同時觸發兩個非同步請求,並使用 allOf 等待兩個請求完成。一旦完成,我們就會檢索結果並相應地更新 UI,所有這些都不會阻塞主執行緒。
連結和完成階段
CompletableFuture 實作了 CompletionStage 接口,為鍊式運算提供了基礎。每個 thenApply、thenAccept 和類似方法都會傳回另一個 CompletionStage,讓您可以建立複雜的非同步管道。
類似於當我們要依次執行一系列非同步任務時如何在 JavaScript 中連結 Promise,我們可以在 Completable Future 中連結任務,以便創建一系列依賴的非同步操作,而不會陷入回調地獄。我們的做法如下:
CompletableFuture.supplyAsync(() -> "Hello") .thenApply(result -> result + ", CompletableFuture") .thenApply(result -> result + " in Java") .thenAccept(System.out::println);
處理例外
當我們在 Promise 物件上使用 .catch() 時,我們在 Completable Future 上使用 .exceptionally() 。此方法處理非同步處理過程中可能出現的異常:
CompletableFuture.supplyAsync(() -> { if (true) { throw new RuntimeException("Exception in CompletableFuture!"); } return "No exception"; }).exceptionally(ex -> { System.out.println("Handled exception: " + ex); return "Recovered value"; }).thenAccept(System.out::println);
我希望這篇文章為您提供一個很好的起點來進一步探索 CompletableFuture 類別。
有用連結:
- 並發深度探究:CompletableFuture 指南
- Java 非同步程式設計綜合介紹 - Promise、Callbacks 和 Futures
以上是本週我學習了:CompletableFuture – Java 的非同步程式設計方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

類加載器通過統一的類文件格式、動態加載、雙親委派模型和平台無關的字節碼,確保Java程序在不同平台上的一致性和兼容性,實現平台獨立性。

Java編譯器生成的代碼是平台無關的,但最終執行的代碼是平台特定的。 1.Java源代碼編譯成平台無關的字節碼。 2.JVM將字節碼轉換為特定平台的機器碼,確保跨平台運行但性能可能不同。

多線程在現代編程中重要,因為它能提高程序的響應性和資源利用率,並處理複雜的並發任務。 JVM通過線程映射、調度機制和同步鎖機制,在不同操作系統上確保多線程的一致性和高效性。

Java的平台獨立性是指編寫的代碼可以在任何安裝了JVM的平台上運行,無需修改。 1)Java源代碼編譯成字節碼,2)字節碼由JVM解釋執行,3)JVM提供內存管理和垃圾回收功能,確保程序在不同操作系統上運行。

Javaapplicationscanindeedencounterplatform-specificissuesdespitetheJVM'sabstraction.Reasonsinclude:1)Nativecodeandlibraries,2)Operatingsystemdifferences,3)JVMimplementationvariations,and4)Hardwaredependencies.Tomitigatethese,developersshould:1)Conduc

云计算显著提升了Java的平台独立性。1)Java代码编译为字节码,由JVM在不同操作系统上执行,确保跨平台运行。2)使用Docker和Kubernetes部署Java应用,提高可移植性和可扩展性。

Java'splatformindependenceallowsdeveloperstowritecodeonceandrunitonanydeviceorOSwithaJVM.Thisisachievedthroughcompilingtobytecode,whichtheJVMinterpretsorcompilesatruntime.ThisfeaturehassignificantlyboostedJava'sadoptionduetocross-platformdeployment,s

容器化技術如Docker增強而非替代Java的平台獨立性。 1)確保跨環境的一致性,2)管理依賴性,包括特定JVM版本,3)簡化部署過程,使Java應用更具適應性和易管理性。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

Atom編輯器mac版下載
最受歡迎的的開源編輯器

Dreamweaver Mac版
視覺化網頁開發工具

SublimeText3 Linux新版
SublimeText3 Linux最新版