Java多条件排序使用Comparator和thenComparing【包含排序List<Map<String, String>>】

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/

**看完如果对你有帮助,感谢点击下面的点赞支持!

哈哈\]\[抱拳\]** ![在这里插入图片描述](https://file.jishuzhan.net/article/1720241796442755073/01caa38286976a2e678dd2150eae0462.webp) **加油!** **共同努力!** **Keafmd** **感谢支持牛哄哄的柯南,期待你的三连+关注\~\~** **keep accumulate for my dream【共勉】** ↓ ↓ ↓ ↓ ↓ ↓

相关推荐
朱剑君3 分钟前
第六天——贪心算法——字符串分隔
算法
荔枝吻7 分钟前
【抽丝剥茧知识讲解】引入mybtis-plus后,mapper实现方式
java·sql·mybatis
在未来等你13 分钟前
互联网大厂Java求职面试:构建高并发直播平台的架构设计与优化
java·spring boot·微服务·kubernetes·高并发·分布式系统·直播平台
小刘不想改BUG21 分钟前
LeetCode LCR 015. 找到字符串中所有字母异位词 (Java)
linux·算法·leetcode
灵典33627 分钟前
数据结构入门-二叉树的层序遍历
数据结构·算法
范纹杉想快点毕业31 分钟前
以项目的方式学QT开发(三)——超详细讲解(120000多字详细讲解,涵盖qt大量知识)逐步更新!
c语言·开发语言·c++·qt·mysql·算法·命令模式
补三补四33 分钟前
随机森林(Random Forest)
人工智能·科技·算法·随机森林·机器学习
轮到我狗叫了36 分钟前
力扣.1471数组的k个最强值,力扣.1471数组的k个最强值力扣1576.替换所有的问号力扣1419.数青蛙编辑力扣300.最长递增子序列
java·数据结构·算法
秋野酱1 小时前
基于SpringBoot的家政服务系统设计与实现(源码+文档+部署讲解)
java·spring boot·后端
趁你还年轻_1 小时前
常用的Java工具库
java