Java多条件排序使用Comparator和thenComparing
在Java中,对一个列表或集合进行排序时,经常需要基于多个条件来排序。幸运的是,Java提供了强大的
Comparator
接口,以及thenComparing
方法,使我们能够轻松地实现多条件排序。
Comparator接口简介
Comparator
接口是Java用于自定义对象排序的关键接口。它包含了一个compare
方法,允许我们定义如何比较两个对象。通常,我们会使用Comparator
来排序列表或集合中的自定义对象。
使用Comparator排序
首先,让我们看看如何使用Comparator
来对一个包含自定义对象的列表进行排序。假设我们有一个包含学生对象的列表,每个学生对象都有姓名和分数属性。
java
class Student {
String name;
int score;
// 构造函数和其他方法省略
}
我们想要按照分数从高到低排序,可以使用Comparator
:
java
List<Student> students = new ArrayList<>();
// 填充学生列表
students.sort(new Comparator<Student>() {
@Override
public int compare(Student s1, Student s2) {
return s2.score - s1.score; // 按分数降序排序
}
});
这将按照学生的分数降序排序列表。
使用thenComparing实现多条件排序
有时,我们需要按照多个条件进行排序,比如首先按分数降序排序,然后按照姓名升序排序。这时,thenComparing
方法派上用场。
java
students.sort(Comparator.comparing((Student s) -> s.score)
.reversed()
.thenComparing(s -> s.name));
Comparator.comparing
方法用于指定首要排序条件,这里是分数,.reversed()
用于指定降序排序。- 紧接着,我们使用
thenComparing
方法,指定次要排序条件,这里是姓名。
这个排序操作将首先按照分数降序排序,然后如果分数相同,将按照姓名升序排序。
当使用方法引用的方式来创建
Comparator
时,可以使用类名::
属性名的语法。
java
students.sort(Comparator.comparing(Student::getScore).reversed()
.thenComparing(Student::getName));
在这个示例中,我们使用 Student::getScore
来引用 Student
类中的 getScore
方法,这与直接使用 lambda 表达式 s -> s.getScore()
具有相同的效果。同样,我们也使用 Student::getName
引用了 getName
方法,以便按照姓名进行次要排序。这使得代码更加简洁和可读,但效果是一样的。
使用thenComparing排序Map
有时,我们需要对包含键值对的Map
进行排序,也可以使用thenComparing
方法。假设我们有一个包含多个属性的Map
列表,并且需要按照这些属性依次排序。
java
List<Map<String, String>> compareResults = new ArrayList<>();
// 填充Map列表
compareResults = compareResults.stream()
.sorted(Comparator.comparing((Map<String, String> i) -> i.get("bgsj"))
.thenComparing(i -> i.get("bgnr"))
.thenComparing(i -> i.get("bgzd"))
.thenComparing(i -> i.get("bgzj")))
.collect(Collectors.toList());
在这个示例中,我们有一个compareResults
列表,其中包含了多个Map
对象,每个Map
表示一条变更信息,包括"bgsj"(变更时间)、"bgnr"(变更内容)、"bgzd"(变更字段)和"bgzj"(变更ID)属性。我们使用thenComparing
方法来对compareResults
列表进行多条件排序。
- 首先,我们使用
Comparator.comparing
方法按照"bgsj"字段进行排序。 - 如果"bgsj"相同,我们使用
thenComparing
方法按照"bgnr"字段进行排序。 - 如果"bgnr"也相同,继续使用
thenComparing
方法按照"bgzd"字段进行排序。 - 最后,如果"bgzd"也相同,将按照"bgzj"字段进行排序。
这使得我们可以按照多个条件对compareResults
列表进行排序,以满足不同排序需求。
多条件排序是Java中非常有用的功能,可以帮助您处理各种排序需求,无论是对自定义对象的排序还是对包含键值对的Map
的排序。使用Comparator
接口和thenComparing
方法,可以轻松实现这些需求,使您的代码更加灵活和强大。
版权声明:
原创博主:牛哄哄的柯南
博主原文链接:https://keafmd.blog.csdn.net/
个人博客链接:https://www.keafmd.top/
看完如果对你有帮助,感谢点击下面的点赞支持!
[哈哈][抱拳]
加油!
共同努力!
Keafmd
感谢支持牛哄哄的柯南,期待你的三连+关注~~
keep accumulate for my dream【共勉】
↓ ↓ ↓ ↓ ↓ ↓