使用流排序时Comparator.reverseOrder() 和 reversed()的区别

发布时间 2023-07-18 01:11:00作者: 翎野君

两种排序方式 

Comparator.reverseOrder() 和 reversed()的区别是前者以某字段进行倒序排列,而reversed是针对已排序数据进行处理,常常用于比较器的末尾。

在使用Stream sorted进行排序的时候,常常需要按照摸个属性进行降序排列,有时候reverseOrder() 和 reversed()都可以实现目标,那他们的区别是什么呢?

区别与不同

reversed

reversed是先排序再取反:作用于已经根据全部指定属性排序数据,目标是实现数据排序翻转。语法规则:

default Comparator<T> reversed() 

返回一个比较器,强制获取该比较器的相反顺序结果。案例分析:按照年龄降序排列

Comparator.comparing(UserDTO::getAge).reversed();

reverseOrder

功能是以某字段倒序方式,从而实现对数据进行排序,而reversed是针对已排序数据进行处理。源码定义:

public static <T extends Comparable<? super T>> Comparator<T> reverseOrder() {
    return Collections.reverseOrder();
 }

调用集合类Collections里的 reverseOrder() 返回一个与自然排序相反的比较器。语法:

Comparator.comparing(类::属性, Comparator.reverseOrder());

使用案例:

Comparator.comparing(UserDTO::getAge, Comparator.reverseOrder());

为了避免混淆,构建比较器时推荐使用 reverseOrder:

Comparator.comparing(类::属性一, Comparator.reverseOrder());

 

本篇文章如有帮助到您,请给「翎野君」点个赞,感谢您的支持。

首发链接:https://www.cnblogs.com/lingyejun/p/17557410.html