使用
IntStream.range:
static List<Integer> findSmallPrecedingValues(List<Integer> values) { return IntStream.range(0, values.size() - 1) .filter(i -> values.get(i) < values.get(i + 1)) .mapToObj(values::get) .collect(Collectors.toList());}
它肯定比带有大循环的命令式解决方案更好,但就以惯用方式“使用流”的目标而言仍有些不足。
是否可以检索流中的下一个值?
不,不是这样。我所知道的最好的引用是在
java.util.stream包装说明中:
Iterator,必须生成新的流以重新访问源中的相同元素。
(检索正在 *** 作的当前元素之外的元素意味着可以多次访问它们。)
从技术上讲,我们还可以通过其他几种方式来做到这一点:
- 有状态地(非常)。
- 使用流的
iterator
是 在技术上 还是使用流。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)