微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

为什么在java-8流中没有执行合并器函数减少操作?

参见英文答案 > Java 8 Stream – Reduce function’s combiner not getting executed                                     2个
我试图了解流中的reduce方法是如何工作的.

Stream.of(1,2,3,4,5,6,7).reduce(new ArrayList<>(),(List<Integer> l,Integer a) -> {l.add(a);return l;},(List<Integer> l1,List<Integer> l2) -> {
System.out.println("l1 is" + l1 + "l2 is " + l2);
l1.addAll(l2);
return l1;
}).forEach(System.out::println);

System.out.println(“l1是”l1“l2是”l2“)行永远不会打印出来.
我可以理解发生了什么(List< Integer> l,Integer a) – > {l.add(a); return l;}
有人可以解释为什么不打印?
java docs表示组合两个值的函数,它必须与累加器函数兼容

谢谢,
阿马尔

解决方法

它仅在流并行时被调用.在这种情况下,流值被分成两半(递归地),每一半被缩减为一个列表,然后必须将两个列表组合在一起.

请注意,减少不应该改变作为参数接收的值(在本例中为列表).它应该返回一个新值.在这种情况下,这是一个可变的减少(即collect())是一个更好的选择.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐