我想将并行流中的列表结果收集到一个列表中。让我们看看这段代码来更好地解释我的问题。这就是我得到的:
List<Object> a = new ArrayList<>();
List<List<Object>> result a.parallelStream() // I get a List of List
.map(a -> { return new ArrayList(); })
.collect(Collectors.toList());
但我真正想拥有的更像是这样:
List<Object> a = new ArrayList<>();
List<Object> result a.parallelStream() // I want to add all list elements into one List of objects
.map(a -> { return new ArrayList(); })
.collect(Collectors.???);
答案 0 :(得分:5)
flatMap
可以将内部列表的元素折叠为单个列表:
List<List<Object>> a = ...
List<Object> result = a.stream()
.flatMap (l -> l.stream())
.collect(Collectors.toList());