加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

Java流排序2个变量升序/退出

发布时间:2020-12-14 05:29:17 所属栏目:Java 来源:网络整理
导读:我想排序seq1升序和seq2降序,所以我这样做: list = list.stream().sorted(comparing(AClass::getSeq1).thenComparing( AClass::getSeq2).reversed()).collect(toList()); 但是结果出来,因为seq1和seq2都按降序排序. 我可以这样做,使seq1升序和seq2降序: so
我想排序seq1升序和seq2降序,所以我这样做:
list = list.stream().sorted(comparing(AClass::getSeq1).thenComparing(        
   AClass::getSeq2).reversed()).collect(toList());

但是结果出来,因为seq1和seq2都按降序排序.

我可以这样做,使seq1升序和seq2降序:

sorted(comparing(AClass::getSeq1)
   .reversed().thenComparing(AClass::getSeq2).reversed()

真正做到这一点的正确方法是什么?

解决方法

在第一个例子中,反向适用于整个比较器,比较seq1,然后按顺序比较seq2.

你所需要的只是反转第二个比较,可以做到这一点,例如:

import static java.util.Collections.reverSEOrder;
import static java.util.Comparator.comparing;

list = list.stream().sorted(
                        comparing(AClass::getSeq1)
                       .thenComparing(reverSEOrder(comparing(AClass::getSeq2))))
                       .collect(toList());


//or you could also write:

list = list.stream().sorted(
                        comparing(AClass::getSeq1)
                       .thenComparing(comparing(AClass::getSeq2).reversed()))
                       .collect(toList());

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读