由于只有4个元素通过过滤器,因此limit(10)
永远不会达到10个元素,因此Stream管道不断生成新元素并将它们提供给过滤器,尝试达到通过过滤器的10个元素,但由于只有前4个元素通过了过滤器,处理永远不会结束(至少直到i
溢出).
Stream管道不够智能,不知道没有更多元素可以通过过滤器,因此它会继续处理新元素.
由于只有4个元素通过过滤器,因此limit(10)
永远不会达到10个元素,因此Stream管道不断生成新元素并将它们提供给过滤器,尝试达到通过过滤器的10个元素,但由于只有前4个元素通过了过滤器,处理永远不会结束(至少直到i
溢出).
Stream管道不够智能,不知道没有更多元素可以通过过滤器,因此它会继续处理新元素.
翻转limit
和filter
子句有不同的行为.
如果放置第limit
一个,则流将首先生成10个整数[1..10],然后过滤它们,只留下小于5的整数.
在原始排序中,filter
首先应用整数,生成并过滤整数,直到达到10个元素.这不是一个无限的运营商,因为i
供应商最终会溢出,但需要一段时间,特别是在慢速计算机上,才能达到MAX_INT
.
如果你想停止或者如果达到编号为5或10种元素收集,还有Stream.takeWhile()
在Java的9添加方法:
Listinteger = Stream.generate(new Supplier () { int i = 0 ; @Override public Integer get() { return ++i; } }).takeWhile(j -> j < 5).limit(10).collect(Collectors.toList());
在供应商溢出并开始产生负数后,它将完成.结果列表将包含:
[1, 2, 3, 4, -2147483648, -2147483647, -2147483646, -2147483645, -2147483644, -2147483643]
其原因在于其他答案.在我的i7机器上完成需要40秒.