91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

分析Java8使用工廠方法supplyAsync創建CompletableFuture

發布時間:2021-11-04 17:25:49 來源:億速云 閱讀:468 作者:iii 欄目:開發技術

這篇文章主要介紹“分析Java8使用工廠方法supplyAsync創建CompletableFuture”,在日常操作中,相信很多人在分析Java8使用工廠方法supplyAsync創建CompletableFuture問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”分析Java8使用工廠方法supplyAsync創建CompletableFuture”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

使用工廠方法 supplyAsync創建 CompletableFuture

采用 supplyAsync 方法后,可以用一行代碼重寫getPriceAsync 方法。

【使用工廠方法 supplyAsync 創建 CompletableFuture 對象】

public Future<Double> getPriceAsync(String product) {
	return CompletableFuture.supplyAsync(() -> calculatePrice(product));
}

supplyAsync 方法接受一個生產者( Supplier )作為參數,返回一個 CompletableFuture對象,該對象完成異步執行后會讀取調用生產者方法的返回值。

生產者方法會交由 ForkJoinPool池中的某個執行線程( Executor )運行,但是你也可以使用 supplyAsync 方法的重載版本,傳遞第二個參數指定不同的執行線程執行生產者方法。

一般而言,向 CompletableFuture 的工廠方法傳遞可選參數,指定生產者方法的執行線程是可行的,后面我們會會介紹如何使用適合你應用特性的執行線程改善程序的性能。

對比

剛剛的代碼

public Future<Double> getPriceAsync(String product) {
	return CompletableFuture.supplyAsync(() -> calculatePrice(product));
}

getPriceAsync 方法返回的 CompletableFuture 對象和 下面的代碼

public Future<Double> getPriceAsync(String product) {
	CompletableFuture<Double> futurePrice = new CompletableFuture<>();
	new Thread( () -> {
		try {
			double price = calculatePrice(product);
			futurePrice.complete(price);
	} catch (Exception ex) {
			futurePrice.completeExceptionally(ex);
	}
	}).start();
	return futurePrice;
}

手工創建和完成的 CompletableFuture 對象是完全等價的,這意味著它提供了同樣的錯誤管理機制,而前者你花費了大量的精力才得以構建。

對CompletableFuture async的理解

驗證代碼如下

ExecutorService executorService = Executors.newFixedThreadPool(3);
        //executorService.submit(new RuleTestRunnable(1));
        List<Integer> taskList = new ArrayList<>();
        for (int i = 0; i < 30; i++) {
            taskList.add(i);
        }
        CompletableFuture<String> a1 = CompletableFuture.supplyAsync(() -> {
            logger.info("線程1{}{}","開始");
 
            try {
                TimeUnit.MILLISECONDS.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            logger.info("線程1{}{}","結束");
            return "1";
        },executorService);
       CompletableFuture<String> a2 = CompletableFuture.supplyAsync(() -> {
 
            logger.info("線程2{}{}","開始");
            try {
                TimeUnit.MILLISECONDS.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            logger.info("線程2{}{}","結束");
            return "1";
        },executorService);
        CompletableFuture<Object> a= a1.thenCombineAsync(a2,(s1,s2) -> {
            logger.info("組合線程{}{}");
            return  s1+s2;
        },executorService);
        Object result = a.get();

當executorService線程池大小為2時候,執行結果如下:

[pool-4-thread-1] INFO test.rcd.thread.CompletableFutureDemo.lambda$mains$4:127 - 組合線程{}{}

a1.thenCombineAsync方法始終被線程1或2執行

當executorService線程池大小為3時候,執行結果如下:

[pool-4-thread-3] INFO test.rcd.thread.CompletableFutureDemo.lambda$mains$4:127 - 組合線程{}{}

a1.thenCombineAsync方法始終被線程3執行

改為a1.thenCombine(),執行結果:

a1.thenCombineAsync方法始終被線程1或2執行

由此可見,async方法始終嘗試取新線程執行方法,不帶async方法則會從當前線程里取線程執行.CompletableFuture似是與線程無關的。

到此,關于“分析Java8使用工廠方法supplyAsync創建CompletableFuture”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

郓城县| 渭源县| 礼泉县| 新安县| 亳州市| 安泽县| 策勒县| 鹤壁市| 涿鹿县| 遂平县| 龙泉市| 绥江县| 金坛市| 陕西省| 阿城市| 大渡口区| 安国市| 城口县| 八宿县| 龙胜| 五原县| 宁武县| 武义县| 文成县| 高青县| 偃师市| 鸡西市| 客服| 峨山| 民勤县| 临澧县| 普兰店市| 沧州市| 通渭县| 微山县| 南投县| 壤塘县| 金寨县| 左贡县| 城市| 阳信县|