如何使用stream reduce保留所有列表列表

时间:2015-04-23 14:26:08

标签: java-8 java-stream

我面临以下问题。我有一个列表列表,我只想保留所有。我正在尝试使用流

null

不幸的是我收到了错误

private List<List<Long>> ids = new ArrayList<List<Long>>();

// some ids.add(otherLists);  

List<Long> reduce = ids.stream().reduce(ids.get(0), (a, b) -> a.addAll(b));

2 个答案:

答案 0 :(得分:22)

如果你想减少(我认为你的意思是扁平)列表清单,你应该这样做:

import static java.util.stream.Collectors.toList

...

List<Long> reduce = ids.stream().flatMap(List::stream).collect(toList());

使用reduce,第一个值应该是您的实现中不是这种情况的标识值,并且您的解决方案会在并行运行流时产生意外结果(因为addAll修改了列表在适当的位置,在这种情况下,标识值将是部分结果的相同列表)。

您需要复制部分结果列表的内容,并在其中添加其他列表,以便在管道并行运行时使其工作:

List<Long> reduce = ids.parallelStream().reduce(new ArrayList<>(), (a, b) -> {
    List<Long> list = new ArrayList<Long>(a);
    list.addAll(b);
    return list;
 });

答案 1 :(得分:3)

addAll返回一个布尔值,而不是两个列表的并集。你想要

List<Long> reduce = ids.stream().reduce(ids.get(0), (a, b) -> {
    a.addAll(b);
    return a;
});