使用流排序时Comparator.reverseOrder() 和 reversed()的区别
两种排序方式
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());
本篇文章如有帮助到您,请给「翎野君」点个赞,感谢您的支持。
作者:翎野君
出处:http://www.cnblogs.com/lingyejun/
若本文如对您有帮助,不妨点击一下右下角的【推荐】。
如果您喜欢或希望看到更多我的文章,可扫描二维码关注我的微信公众号《翎野君》。
转载文章请务必保留出处和署名,否则保留追究法律责任的权利。
出处:http://www.cnblogs.com/lingyejun/
若本文如对您有帮助,不妨点击一下右下角的【推荐】。
如果您喜欢或希望看到更多我的文章,可扫描二维码关注我的微信公众号《翎野君》。
转载文章请务必保留出处和署名,否则保留追究法律责任的权利。