Future和CompletableFuture區別

来源:https://www.cnblogs.com/xietingwei/archive/2023/08/21/17647249.html
-Advertisement-
Play Games

- Future :獲取非同步返回的結果需要使用輪詢的方式,消耗cup ```java ExecutorService executorService = Executors.newFixedThreadPool(10); Future future = executorService.submit( ...


  • Future :獲取非同步返回的結果需要使用輪詢的方式,消耗cup

            ExecutorService executorService = Executors.newFixedThreadPool(10);
    
            Future<String> future = executorService.submit(()->{
                try {
                    Thread.sleep(2000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                return "future";
            });
            while(true){
                if(future.isDone()){
                    System.out.println(future.get());
                    break;
                }
            }
    
  • CompletableFuture:採用觀察者模式,阻塞獲取非同步返回的結果,性能得到優化

    		 System.out.println("=============CompletableFuture===================");
    
    
            CompletableFuture testFuture1 = CompletableFuture.supplyAsync(()->{
                return "麗麗1";
            }).thenApply((element)->{
                System.out.println("testFuture1後續操作:"+element);
                return "麗麗2";
            });
    
            System.out.println(testFuture1.get());
    
    
            System.out.println("=============CompletableFuture===================");
    
    
            CompletableFuture testFuture2 = CompletableFuture.supplyAsync(()->{
                return "麗麗1";
            }).thenAccept((element)->{
                System.out.println("testFuture2後續操作:"+element);
            });
    
            System.out.println(testFuture2.get());
    
  • CompletableFuture的使用明細

    * runAsync 無返回值
    * supplyAsync 有返回值
    *
    * thenAccept 無返回值
    * thenApply 有返回值
    * thenRun 不關心上一步執行結果,執行下一個操作
    * get() 為阻塞獲取 可設置超時時間 避免長時間阻塞
    
    實現介面 AsyncFunction 用於請求分發
    
    定義一個callback回調函數,該函數用於取出非同步請求的返回結果,並將返回的結果傳遞給ResultFuture 
    
    對DataStream的數據使用Async操作
    
    • 例子

      /**
       * An implementation of the 'AsyncFunction' that sends requests and sets the callback.
        *  通過向資料庫發送非同步請求並設置回調方法
       */
      class AsyncDatabaseRequest extends RichAsyncFunction<String, Tuple2<String, String>> {
      
          /** The database specific client that can issue concurrent requests with callbacks 
           可以非同步請求的特定資料庫的客戶端 */
          private transient DatabaseClient client;
      
          @Override
          public void open(Configuration parameters) throws Exception {
              client = new DatabaseClient(host, post, credentials);
          }
      
          @Override
          public void close() throws Exception {
              client.close();
          }
      
          @Override
          public void asyncInvoke(String key, final ResultFuture<Tuple2<String, String>> resultFuture) throws Exception {
      
              // issue the asynchronous request, receive a future for result
              // 發起一個非同步請求,返回結果的 future
              final Future<String> result = client.query(key);
      
              // set the callback to be executed once the request by the client is complete
              // the callback simply forwards the result to the result future
              // 設置請求完成時的回調.將結果傳遞給 result future
              CompletableFuture.supplyAsync(new Supplier<String>() {
              
                  @Override
                  public String get() {
                      try {
                          return result.get();
                      } catch (InterruptedException | ExecutionException e) {
                          // Normally handled explicitly.
                          return null;
                      }
                  }
              }).thenAccept( (String dbResult) -> {
                  resultFuture.complete(Collections.singleton(new Tuple2<>(key, dbResult)));
              });
          }
      }
      
      // create the original stream
      // 創建一個原始的流
      DataStream<String> stream = ...;
      
      // apply the async I/O transformation
      // 添加一個 async I/O ,指定超時時間,和進行中的非同步請求的最大數量
      DataStream<Tuple2<String, String>> resultStream =
          AsyncDataStream.unorderedWait(stream, new AsyncDatabaseRequest(), 1000, TimeUnit.MILLISECONDS, 100);
      
      
    • 註意事項

      • Timeout:定義請求超時時間,非同步請求多久沒完成會被認為是超時了
      • Capacity:定義了同時進行的非同步請求的數量,可以限制併發請求數量,不會積壓過多的請求
      • 超時處理:預設當一個非同步 I/O 請求超時時,會引發異常並重新啟動作業。 如果要處理超時,可以覆蓋該AsyncFunction的timeout方法來自定義超時之後的處理方式
      • 響應結果的順序:AsyncDataStream包含兩種輸出模式,
        • unorderedWait無序:響應結果的順序與非同步請求的順序不同
        • orderedWait有序:響應結果的順序與非同步請求的順序相同

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ## 直連 直連模式下,選擇一個玩家充當伺服器(房主)。如果游戲出現不同步,那麼均按房主的世界來,玩家1可以作弊修改其游戲來影響其他玩家的世界 針對兩個玩家來說,直連連接質量更好,延遲小 如果玩家數量很多,不同玩家間的通信則需要靠房主為中介,那通信質量與房主主機配置、網路情況有很大關係 ## 專用服 ...
  • 從研發的角度來看如果系統上下文清晰、應用架構設計簡單、應用拆分合理應該稱之為架構合理。基於以上的定義可以從以下三個方面來梳理評估: ...
  • ### 歡迎訪問我的GitHub > 這裡分類和彙總了欣宸的全部原創(含配套源碼):[https://github.com/zq2599/blog_demos](https://github.com/zq2599/blog_demos) ### 本篇概覽 - 前文[《Docker下elasticse ...
  • ## 面向對象三要素 封裝:顧名思義,將函數或變數集中定義在類中,而非散亂分佈。 繼承:擴展類的功能。 多態:在擴展類的功能的基礎之上,實現其內部方法的多樣性。 ### 多態的本質 針對某個類型的方法調用,其真正執行的方法取決於運行時期實際類型的方法。 ```java package Project ...
  • 之前用的python2.7+robotframework進行的自動化測試,python3的還沒嘗試,今天嘗試了下,搭建環境的時候也是各種報錯,搞了幾小時才搞好了。 一、python安裝 下載python然後安裝,地址:https://www.python.org/,安裝時勾選添加到環境變數,安裝後c ...
  • ## 一、前言 - 還在為排查Java程式線上問題頭痛嗎,看我們用阿裡開源的診斷神器 Arthas 來幫您 - 本文開篇主要介紹 阿裡開源的診斷神器Arthas 3.7.0版本,watch、jad、classloader 命令,以 Debian 11、openjdk 11 為例 ## 二、Artha ...
  • ## 題目描述 給你兩個 非空 的鏈表,表示兩個非負的整數。它們每位數字都是按照 逆序 的方式存儲的,並且每個節點只能存儲 一位 數字。請你將兩個數相加,並以相同形式返回一個表示和的鏈表。你可以假設除了數字 0 之外,這兩個數都不會以 0 開頭。 ## 例子 > 輸入:l1 = [2,4,3], l ...
  • 虛擬機類載入的時機和過程 一、類載入的時機 類從被載入到虛擬機記憶體中開始,到卸載出記憶體為止,它的整個生命周期包括:載入(Loading)、驗證(Verification)、準備(Preparation)、解析(Resolution)、初始化(Initialization)、使用(Using)和卸載( ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...