gpt4 book ai didi

java - 当一个依赖于另一个时,如何将 CompletableFuture 的两个结果结合起来?

转载 作者:行者123 更新时间:2023-12-04 17:23:00 27 4
gpt4 key购买 nike

有两种服务:

  1. Service1 返回 ids1 列表;
  2. Service2 返回 id1 的 ids2 列表:

如何使用 CompletableFutureid1 -> [id2, id2, id2, ...] 对结果进行分组?
我想把它全部放到 HashMap 中,但我不明白如何将 ids1 传递给第二个 Future。我正在考虑使用 thenCombine(ids1Future, (v1, v2) -> {...}),但对我来说它看起来很丑陋。是否有任何“最佳实践”可以做到这一点?

这里不是异步方式:

Map<ID1, List<ID2>> idsMap = new HashMap();

List<IDS1> ids1List = service1.service.find();

for (ID1 id1: IDS1) {
List<IDS2> ids2List = service2.findById(id1);
idsMap.put(id1, ids2List);
}
service2.process(idsMap);

尝试异步执行:

CompletableFuture<List<IDS1>> ids1Future
= CompletableFuture.supplyAsync(() -> service.find());

ids1Future.thenApply((ids1) -> {
CompletableFuture<List<IDS2>> listFutureIds2
= ids1.stream().map(id1
-> CompletableFuture.supplyAsync(()
-> service2.getById(id1)))
.collect(Collectors.toList());

CompletableFuture<Void> allFuturesDone
= CompletableFuture.allOf(
listFutureIds2.toArray(
new CompletableFuture[listFutureIds2.size()]));
allFuturesDone.thenApply(v
-> list.stream()
.map(CompletableFuture::join)
.collect(toList()));

});

最佳答案

这是一个如何使用 Fork/Join 将字符列表转换为字符串列表的示例,其中每个字符串都是该字符的 N 次复制。您可以根据自己的情况调整此示例。

希望这就是您要找的。

import java.util.Collection;
import java.util.List;
import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.ForkJoinTask;
import java.util.concurrent.RecursiveTask;
import java.util.stream.Collectors;

public class ForkJoinExample {

public static class RepeatTask extends RecursiveTask<List<String>> {

private final List<Character> chars;
private final int repeatCount;

public RepeatTask(List<Character> chars, int repeatCount) {
this.chars = chars;
this.repeatCount = repeatCount;
}

public RepeatTask(Character c, int repeatCount) {
this.chars = List.of(c);
this.repeatCount = repeatCount;
}

@Override
protected List<String> compute() {
if (chars.size() > 1) {
ForkJoinTask.invokeAll(chars.stream().map(c -> new RepeatTask(c, repeatCount)).collect(Collectors.toList()));
return ForkJoinTask.invokeAll(chars.stream().map(c -> new RepeatTask(c, repeatCount)).collect(Collectors.toList()))
.stream()
.map(ForkJoinTask::join)
.flatMap(Collection::stream)
.collect(Collectors.toList());
}
return List.of(String.valueOf(chars.get(0)).repeat(Math.max(0, repeatCount)));
}

}

public static void main(String[] args) {
ForkJoinPool commonPool = ForkJoinPool.commonPool();
RepeatTask task = new RepeatTask(List.of('a', 'b', 'c'), 4);
commonPool.execute(task);
System.out.println(task.join());
}
}

结果是这个:[aaaa, bbbb, cccc]

关于java - 当一个依赖于另一个时,如何将 CompletableFuture 的两个结果结合起来?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65026701/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com