【Java】List排序方法(包括对象、Map等内部排序实现)

前言



一、常规排序

/**
* String类型的集合排序
*/
void stringListTest() {
        List<String> list = Arrays.asList("王羲之", "张三丰", "vbe", "123", "李斯", "bf", "王淼", "鬼谷子", "415", "秦始皇");
    	list.sort(String::compareTo); 		  	// 正序
    	list.sort(Comparator.reverseOrder()); 	// 逆序
    	// Collections.sort(list);
    	// Collections.sort(list,Comparator.reverseOrder());
}
// 排序前:[王羲之, 张三丰, vbe, 123, 李斯, bf, 王淼, 鬼谷子, 415, 秦始皇]
// 正序后:[123, 415, bf, vbe, 张三丰, 李斯, 王淼, 王羲之, 秦始皇, 鬼谷子]
// 逆序后:[鬼谷子, 秦始皇, 王羲之, 王淼, 李斯, 张三丰, vbe, bf, 415, 123]

/**
* Integer类型的集合排序
*/
void integerListTest() {
        List<Integer> list = Arrays.asList(2, 4, 1, 54, 2);
        list.sort(Integer::compareTo);			// 正序
        list.sort(Comparator.reverseOrder());	// 逆序
}
// 排序前:[2, 4, 1, -3, 34, -123, 0, 54, 2]
// 正序后:[-123, -3, 0, 1, 2, 2, 4, 34, 54]
// 逆序后:[54, 34, 4, 2, 2, 1, 0, -3, -123]

二、内部属性排序

实体类
@Data
public class People {
    private String name;	// 姓名
    private Integer age;	// 年龄
}
对内部属性排序
// 创建peopleList数据进行测试
// 排序前:[People(name=鬼谷子, age=2), People(name=bf, age=26), People(name=鬼谷子, age=44), People(name=王淼, age=99)]
List<People> peopleList = new ArrayList<>();

// 对象单个属性正序排序
// [People(name=鬼谷子, age=2), People(name=bf, age=26), People(name=鬼谷子, age=44), People(name=王淼, age=99)]
peopleList.sort(Comparator.comparing(People::getAge));

// 对象多个属性正序排序
// [People(name=bf, age=26), People(name=王淼, age=99), People(name=鬼谷子, age=2), People(name=鬼谷子, age=44)]
peopleList.sort(Comparator.comparing(People::getName).thenComparing(People::getAge);

// 对象多个对象排序,并且要求年龄倒序(先对name正序,然后对age倒序)
// [People(name=bf, age=26), People(name=王淼, age=99), People(name=鬼谷子, age=44), People(name=鬼谷子, age=2)]
peopleList.sort(Comparator.comparing(People::getName).thenComparing(People::getAge, Comparator.reverseOrder()));
posted @ 2022-08-15 01:31  中国制造  阅读(32)  评论(0编辑  收藏  举报