我有一个我希望自然排序的对象流,但也强迫其中一个成员永远是第一个。
例如:
List<String> result = Stream.of("a", "s", "d", "f")
.sorted(Comparator.comparing((String s) -> !s.equals("d"))
.thenComparing(Comparator.naturalOrder()))
.collect(toList());
System.out.println(result);
这会产生
[d, a, f, s]
即按字母顺序排列,但有&#34; d&#34;第一
我注意到我也可以使用多个.sorted(...)
来电来写这个:
List<String> result = Stream.of("a", "s", "d", "f")
.sorted()
.sorted(Comparator.comparing(s -> !s.equals("d")))
.collect(toList());
System.out.println(result);
这会产生相同的结果,并且IMO更具可读性。
但是,我没有看到其他人这样做的例子。
此外,IntelliJ IDEA将第一个.sorted()
调用标记为冗余。它说&#34;随后&#39;排序&#39;电话使排序无用&#34;。
这显然是不真实的,因为删除调用会将输出更改为
[d, a, s, f]
所以我的问题是:对Stream定义的行为进行多次.sorted(...)
调用,或者我只是幸运吗?
换句话说,这是我可以依赖的.sorted()
的支持使用,还是只是现在才能使用,可能会在将来的Java版本中停止工作?
答案 0 :(得分:3)
当你说“已定义”时,我假设你问的是“排序稳定”吗?如果是的话那么是的。
第二个示例代码段的第一个sorted()
调用将根据自然顺序对元素进行排序,然后根据提供的比较器再次对进行排序。
第二种方法的问题是效率低下,因为它需要两次排序操作,因此可能会决定继续第一种方法。