我想排序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());