java for循环 等待,使用Java中的CompletableFuture并行执行for循环并记录执行

I have a for loop which I am trying to parallelize using CompletableFuture.

for (int i = 0; i < 10000; i++) {

doSomething();

doSomethingElse();

}

What I have till now is:

for (int i = 0; i < 10000; i++) {

CompletableFuture.runAsync(() -> doSomething());

CompletableFuture.runAsync(() -> doSomethingElse());

}

I guess this serves the purpose but there is a requirement to print log just before the start and end of all the processing. If I do this:

log("Started doing things");

for (int i = 0; i < 10000; i++) {

CompletableFuture.runAsync(() -> doSomething());

CompletableFuture.runAsync(() -> doSomethingElse());

}

log("Ended doing things");

Does this guarantee that the second log statement will be printed once all the for loop is over since that is executing in a separate thread? If not, is there a way to do this without blocking the main thread?

解决方案

You have to collect all CompletableFutures and wait for their complete:

log("Started doing things");

List futures = new ArrayList();

for (int i = 0; i < 10000; i++) {

futures.add(CompletableFuture.runAsync(() -> doSomething()));

futures.add(CompletableFuture.runAsync(() -> doSomethingElse()));

}

CompletableFuture.allOf(futures.toArray(new CompletableFuture[0]))

.thenRunAsync(() -> log("Ended doing things"));

Or when you use the ExecutorService:

CompletableFuture.runAsync(() -> {

try {

executorService.invokeAll(tasks);

} catch (InterruptedException) {

e.printStackTrace();

}

log("Ended doing things");

});

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值