java8的lambda表达式排序,理应用comparing,多字段 后面增加thenComparing,默认排序规则为正序。

排序

现在有个排序需求:a-倒序b-当a相同时,正序c-当b相同时,倒序

正确的写法:

List<UserCouponVo> newList = list.stream().sorted(Comparator
                    .comparing(UserCouponVo::getA,Comparator.reverseOrder())
                    .thenComparing(UserCouponVo::getB)
                    .thenComparing(UserCouponVo::getC,Comparator.reverseOrder())
            ).collect(Collectors.toList());

 

错误的写法:

List<UserCouponVo> newList = list.stream().sorted(Comparator
                    .comparing(UserCouponVo::getA).reversed()
                    .thenComparing(UserCouponVo::getB)
                    .thenComparing(UserCouponVo::getC).reversed()
            ).collect(Collectors.toList());

 

原因:Comparator.comparing(类属性).reversed() 是得到正序结果后再逆序 , .reversed() 是逆反前面的所有排序Comparator.comparing(类属性,Comparator.reverseOrder()); 当前字段直接逆序。

所以,当需求为:a-倒序b-当a相同时,倒序c-当b相同时,倒序

可以写成:

List<UserCouponVo> newList = list.stream().sorted(Comparator
                    .comparing(UserCouponVo::getA)
                    .thenComparing(UserCouponVo::getB)
                    .thenComparing(UserCouponVo::getC).reversed()
            ).collect(Collectors.toList());

 

所以,当需求为:a-正序b-当a相同时,正序c-当b相同时,正序

可以写成:

List<UserCouponVo> newList = list.stream().sorted(Comparator
                    .comparing(UserCouponVo::getA)
                    .thenComparing(UserCouponVo::getB).reversed()
                    .thenComparing(UserCouponVo::getC).reversed()
            ).collect(Collectors.toList());

 

或:

List<UserCouponVo> newList = list.stream().sorted(Comparator
                    .comparing(UserCouponVo::getA)
                    .thenComparing(UserCouponVo::getB)
                    .thenComparing(UserCouponVo::getC)
            ).collect(Collectors.toList());

 

分页:

List<UserCouponVo> newList = list.stream().sorted(Comparator
                    .comparing(UserCouponVo::getA)
                    .thenComparing(UserCouponVo::getB)
                    .thenComparing(UserCouponVo::getC)
            ).skip((bo.getPage() - 1) * bo.getPageSize()).limit(bo.getPageSize())
            .collect(Collectors.toList());

 

有种mysql的既视感