我面临以下问题。我有一个列表列表,我只想保留所有。我正在尝试使用流
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));
答案 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;
});