java stream排序

1. 排序

apples.stream().sorted(Comparator.comparing(Apple::getWeight))

2. 逆序 

如果你想要对苹果按重量递减排序怎么办?用不着去建立另一个Comparator的实例。接口 有一个默认方法reversed可以使给定的比较器逆序。因此仍然用开始的那个比较器,只要修改 一下前一个例子就可以对苹果按重量递减排序: 

apples.stream().sorted(Comparator.comparing(Apple::getWeight).reversed())

3. 比较器链 

上面说得都很好,但如果发现有两个苹果一样重怎么办?哪个苹果应该排在前面呢?你可能 需要再提供一个Comparator来进一步定义这个比较。比如,在按重量比较两个苹果之后,你可 能想要按原产国排序。thenComparing方法就是做这个用的。它接受一个函数作为参数(就像 comparing方法一样),如果两个对象用第一个Comparator比较之后是一样的,就提供第二个 Comparator。你又可以优雅地解决这个问题了: 

apples.stream().sorted(Comparator.comparing(Apple::getWeight).reversed().thenComparing(Apple::getCountry))

按重量递减排序,两个苹果一样重时,进一步按国家排序

你可能感兴趣的:(Java编程)