摘要: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());
对于Wiener以上的话题,大家又有什么自己的独特见解呢?欢迎在下方评论区留言!
标签:Comparator,reversed,comparing,reverseOrder,排序,属性 From: https://www.cnblogs.com/east7/p/17323454.html