使用Iterable< T>,容易:
T last = null; for (T t : iterable) { if (last != null && last.compareTo(t) > 0) { return false; } last = t; } return true;
但是我不能想到一个干净的方法来为Stream< T>做同样的事情.这避免了在不必要时消耗所有元素.
解决方法
有几种方法来迭代流的连续对.例如,您可以查看
this question.当然我最喜欢的方法是使用
the library我写道:
boolean unsorted = StreamEx.of(sourceStream) .pairMap((a,b) -> a.compareTo(b) > 0) .has(true);
它是短路操作:一旦找到错误就会完成.并行流也很好.