我是
java的新功能编程,并且想知道我应该如何编写代码来避免NPE(例如)这个操作:
myList.stream() .reduce((prev,curr) -> prev.getTimestamp().isAfter(curr.getTimestamp()) ? prev : curr); .get().getTimestamp();
我的意图是找到列表中最新对象的时间戳.关于如何更好地收集最后一个元素的建议是非常受欢迎的,但我的主要问题实际上是为什么这个工作.
该文档说,该函数会抛出一个NullPointerException“如果还原的结果为空”:
这是可以的,但是我不太明白的是为什么当这个代码运行时只包含一个元素的列表,我不会得到NullPointerException.在这种情况下,我预计prev为null.我尝试调试,但是当只有一个元素时,它似乎只是跨越整个lambda表达式.
解决方法
正如
reduce的JavaDoc所说,reduce相当于:
boolean foundAny = false; T result = null; for (T element : this stream) { if (!foundAny) { foundAny = true; result = element; } else result = accumulator.apply(result,element); } return foundAny ? Optional.of(result) : Optional.empty();
因此,如果Stream具有单个元素,则循环只有一次迭代,并且返回在该迭代中找到的单个元素.
只有当Stream至少有两个元素时才会应用BinaryOperator.