Java中List排序的3种方法

时间:2024-11-17 07:27:29

// 打印 list 集合

(p -> {

§;

});

}

}

// 以下 set/get/toString 使用的是 lombok 的注解

@Getter

@Setter

@ToString

class Person implements Comparable {

private int id;

private int age;

private String name;

public Person(int id, int age, String name) {

= id;

= age;

= name;

}

@Override

public int compareTo(Person p) {

return () - ();

}

}

以上代码的执行结果,如下图所示:

本方法的核心代码如下:

2.使用 Comparator 排序


Comparable 是类内部的比较方法,而 Comparator 是排序类外部的比较器。使用 Comparator 比较器,无需修改原 Person 类,只需要扩充一个 Person 类的比较器就行了,Comparator 的实现方法有以下两种:

  • 新建 Comparator 比较器;

  • 使用 Comparator 匿名类比较器。

其中,第二种实现方法要更简洁一些,我们通过下面的具体代码,来观察一下二者的区别。

2.1 新建 Comparator 比较器

public class ListSortExample2 {

public static void main(String[] args) {

// 创建并初始化 List

List list = new ArrayList() {{

add(new Person(1, 30, “北京”));

add(new Person(2, 20, “西安”));

add(new Person(3, 40, “上海”));

}};

// 使用 Comparator 比较器排序

(list, new PersonComparator());

// 打印 list 集合

(p -> {

§;

});

}

}

/**

* 新建 Person 比较器

*/

class PersonComparator implements Comparator {

@Override

public int compare(Person p1, Person p2) {

return () - ();

}

}

@Getter

@Setter

@ToString

class Person {

private int id;

private int age;

private String name;

public Person(int id, int age, String name) {

= id;

= age;

= name;

}

}

以上代码的执行结果,如下图所示:

本方法的核心实现代码如下:

2.2 匿名类比较器

比较器 Comparator 可以使用更简洁的匿名类的方式,来实现排序功能,具体实现代码如下:

public class ListSortExample2 {

public static void main(String[] args) {

// 创建并初始化 List

List list = new ArrayList() {{

add(new Person(1, 30, “北京”));

add(new Person(2, 20, “西安”));

add(new Person(3, 40, “上海”));

}};

// 使用匿名比较器排序

(list, new Comparator() {

@Override

public int compare(Person p1, Person p2) {

return () - ();

}

});

// 打印 list 集合

(p -> {

§;

});

}

}

@Getter

@Setter

@ToString

class Person {

private int id;

private int age;

private String name;

public Person(int id, int age, String name) {

= id;

= age;

= name;

}

}

以上代码的执行结果,如下图所示:

3.使用 Stream 流排序


在 JDK 8 之后可以使用更加简单的方法 Stream 流来实现排序功能,它的实现只需要一行代码,具体实现如下:

public class ListSortExample3 {

public static void main(String[] args) {

// 创建并初始化 List

List list = new ArrayList() {{

add(new Person(1, 30, “北京”));

add(new Person(2, 20, “西安”));

add(new Person(3, 40, “上海”));

}};

// 使用 Stream 排序

list = ().sorted((Person::getAge).reversed())

.collect(());

// 打印 list 集合

(p -> {

§;

});

}

@Getter

@Setter

@ToString

static class Person {

private int id;

private int age;

private String name;

public Person(int id, int age, String name) {

= id;

= age;

= name;

}

}

}

其中 reversed() 表示倒序的意思,如果不使用此方法则是正序。

以上代码的执行结果,如下图所示:

扩展:排序字段为 null

使用 Stream 进行排序时,如果排序的字段出现 null 值就会导致异常发生,具体示例如下:

public class ListSortExample4 {

public static void main(String[] args) {

// 创建并初始化 List

List list = new ArrayList() {{

add(new Person(30, “北京”));

add(new Person(10, “西安”));

add(new Person(40, “上海”));

add(new Person(null, “上海”)); // 年龄为 null 值

}};

// 按照[年龄]正序,但年龄中有一个 null 值

list = ().sorted((Person::getAge))

.collect(());

// 打印 list 集合
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

金三银四到了,送上一个小福利!

专题+大厂.jpg
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
注Java获取)**

img

最后

金三银四到了,送上一个小福利!

[外链图片转存中…(img-68jmbRju-1713125105635)]

[外链图片转存中…(img-7q2sWBHX-1713125105635)]

[外链图片转存中…(img-oHfUZElg-1713125105635)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!