多个.sorted(...)调用java 8流

时间:2018-06-14 17:10:10

标签: java java-8 java-stream

我有一个我希望自然排序的对象流,但也强迫其中一个成员永远是第一个。

例如:

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版本中停止工作?

1 个答案:

答案 0 :(得分:3)

当你说“已定义”时,我假设你问的是“排序稳定”吗?如果是的话那么是的。

第二个示例代码段的第一个sorted()调用将根据自然顺序对元素进行排序,然后根据提供的比较器再次对进行排序

第二种方法的问题是效率低下,因为它需要两次排序操作,因此可能会决定继续第一种方法。