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

前端之家收集整理的这篇文章主要介绍了Java流排序2个变量升序/退出前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想排序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());

猜你在找的Java相关文章