如何按顺序执行单元表
我有一个要处理的单声道列表,但它们必须按顺序执行,而且只有在前一个单声道完成后才能执行下一个单声道。
private Mono<List<Result>> processGoals(List<> goals,Data data) {
List<Mono<Result>> plans = goals
.stream()
.map(plan -> processGoal(plan, data))
.collect(Collectors.toList());
}
我尝试使用
return Flux.concat(plans).subscribeOn(Schedulers.single()).collectList();
但这会在前一个单声道完成之前执行下一个单声道。
解决方案
Flux#concatMap
是此情况的最佳选择。
它将按顺序合并每个映射的发布者,并一次激活一个发布者,而不必显式定义concurrency
参数。
这里有一个完整的示例:
Flux.fromIterable(goals))
.concatMap(goal -> processGoal(goal, data))
.collectList();
相关文章