JAVA8学习8-Comparator 比较器详解

8 comparator 比较器详解

int compare(T o1, T o2) o1 比 o2 返回负数,o1 比 o2 小,返回 0 相等,返回整数 01 比 02 大。

​ 在java8之后,comparator 是一个函数式接口,对接口进行了增强(增加了相当多的默认方法)。

  1. reversed 倒叙
  2. comparing 比较器(comparingInt 、 comparingLong、comparingDouble)
  3. thenComparing 之后比较(串联比较),如果第一个比较器确定不了顺序,thenComparing 才会起效果

看下下列输出结果跟自己想的是否一样:

package cn.zxhysy.jdk8.comparator;

import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.stream.Collectors;

public class ComparatorTest {

    public static void main(String[] args) {
        List<String> list = Arrays.asList("nihao", "hello", "world", "welcome");
        // 按照字母升序排序
//        Collections.sort(list);

        // 按照字符串的长度升序排序
//        Collections.sort(list, (item1, item2) -> item1.length()-item2.length());
        // comparingInt 接收一个 ToIntFunction, 返回一个比较器(c1,c3) -> c1-c2
        // ToIntFunction 接收一个泛型,返回int类型
//        Collections.sort(list, Comparator.comparingInt(String::length));

        // 按照字符串的长度降序排序
//        list.sort((item1, item2) -> item2.length() - item1.length());
//        list.sort(Comparator.comparingInt(String::length).reversed());
        // 下面例子没加参数类型时报错,加上 String 后不报错。
        // 原因 comparingInt 跟 list.sort 排序时的类型是不可以推断的
        // comparingInt 只是个工厂创建comparator, reversed 方法使类型推断出问题
//        list.sort(Comparator.comparingInt((String item) -> item.length()).reversed());

        // 按照字符串长度排序,再按字符串的字母排序
//        list.sort(Comparator.comparingInt(String::length).thenComparing(String.CASE_INSENSITIVE_ORDER));

//        list.sort(Comparator
//                .comparingInt(String::length)
//                .thenComparing((item1 , item2) -> item1.toLowerCase().compareTo(item2.toLowerCase())));
//        list.sort(Comparator
//                .comparingInt(String::length)
//                .thenComparing(Comparator.comparing(String::toLowerCase)));

//        list.sort(Comparator.comparingInt(String::length)
//                .thenComparing(Comparator.comparing(String::toLowerCase, Comparator.reverseOrder())));
        list.sort(Comparator.comparingInt(String::length)
                .thenComparing(String::toLowerCase, Comparator.reverseOrder()));
        System.out.println(list);
        list.sort(Comparator.comparingInt(String::length).reversed()
                .thenComparing(Comparator.comparing(String::toLowerCase, Comparator.reverseOrder())));

        System.out.println(list);
    }

}

你可能感兴趣的:(java)