第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

并行化 REST 調(diào)用的最佳方法是什么?

并行化 REST 調(diào)用的最佳方法是什么?

明月笑刀無情 2021-09-29 15:26:33
我正在處理一些處理多個(gè) REST 調(diào)用的 Java 代碼call1()call2()call3()...我想并行化這些調(diào)用,但同步執(zhí)行我的主要代碼。我用lamba和并行流制作了一個(gè)POC:List<Runnable> list = new ArrayList();list.add(() -> {call1()});list.add(() -> {call2()});list.add(() -> {call3()});list.add(...);list.parallelStream()            .forEach(Runnable::run);你有其他解決方案嗎?我還檢查了使用來自 Jersey 客戶端的異步調(diào)用,但這需要更多的代碼更改。
查看完整描述

1 回答

?
鴻蒙傳說

TA貢獻(xiàn)1865條經(jīng)驗(yàn) 獲得超7個(gè)贊

您正在尋找的只是異步運(yùn)行您的調(diào)用。您可以使用CompletableFutures 提交任務(wù),然后等待它們完成:


list.stream() //you don't really need a parallel stream

    .map(CompletableFuture::runAsync)

    .collect(Collectors.toList()) //make sure all tasks are submitted

    .stream()

    .forEach(CompletableFuture::join);

這將提交所有任務(wù)(異步運(yùn)行),然后等待每個(gè)任務(wù)完成運(yùn)行。發(fā)生這種情況時(shí),該方法將返回。


您可能需要控制異步任務(wù)的線程池。這是一個(gè)使用 10 線程池的示例:


ExecutorService es = Executors.newFixedThreadPool(10);

list.stream()

    .map(r -> CompletableFuture.runAsync(r, es))

     ...


查看完整回答
反對(duì) 回復(fù) 2021-09-29
  • 1 回答
  • 0 關(guān)注
  • 178 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)