java8的thenComparing如何reversed()倒序

今天在使用Stream排序的时候,出现了一个bug,简单的记录下,方便下次查找

 

首先根据降序的sort方法,对list集合中的对象的某个属性进行排序.float getFollowDegree()的返回值时,所以查询出来后进行排序的顺序是降序(DESC,从大到小)的,如果没有reversed()方法的话,就是升序排列(ASC,从小到大).这样是没有问题的...

  1.  
    //对listResult进行排序,根据伴随度进行降序F
  2.  
    List<FollowIMSI> collect = listResult.stream()
  3.  
    .sorted(Comparator.comparing(FollowIMSI::getFollowDegree).reversed())
  4.  
    .collect(Collectors.toList());

 

下面问题出现了.如果我想先对followDegree降序,如果followDegree相等,再根据codeDaysThirsty的值进行降序排列,很自然的就往后加了....

  1.  
    //根据伴随度和30天出现比率进行排序
  2.  
    List<FollowIMSI> collect1 = list1.stream()
  3.  
    .sorted(Comparator.comparing(FollowIMSI::getFollowDegree).reversed()
  4.  
    .thenComparing(FollowIMSI::getCodeDaysThirsty).reversed())
  5.  
    .collect(Collectors.toList());

 

很多时候,并没有那么多想当然的,从上述代码中可以看到,先对followDegree进行降序排列,再对codeDaysThirty进行降序排列,没有问题....

其实,不然

 

我们需要的是对followDegree的值降序,如果值相等,再对codeDaysThirty进行降序.所以说,上述代码的理解应该为:

以codeDaysThirty进行降序排列,如果codeDaysThirty相等,再以followDegree进行排序.

 

所以正确的代码应该是:

  1.  
    //根据伴随度和30天出现比率进行排序
  2.  
    List<FollowIMSI> collect1 = list1.stream()
  3.  
    .sorted(Comparator.comparing(FollowIMSI::getFollowDegree)
  4.  
    .thenComparing(FollowIMSI::getCodeDaysThirsty).reversed())
  5.  
    .collect(Collectors.toList());

注意在getFollowDegree()后是没有reversed()的....

所以.静下心来,你会理解其中的奥秘,从左往右进行运算的

 

posted on   小甜瓜安东泥  阅读(6138)  评论(0编辑  收藏  举报

(评论功能已被禁用)
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 字符编码:从基础到乱码解决
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示