java中集合排序的常用方法总结

简介: 平常的开发需求中肯定会遇到对集合排序问题,最常见的排序是在持久层中使用sql进行排序,但是由于业务限制或是其他原因,不能在持久层进行排序处理只能在逻辑层处理,那今天就来聊一下如何在逻辑层,不借助持久层进行集合的排序处理.

前言


   平常的开发需求中肯定会遇到对集合排序问题,最常见的排序是在持久层中使用sql进行排序,但是由于业务限制或是其他原因,不能在持久层进行排序处理只能在逻辑层处理,那今天就来聊一下如何在逻辑层,不借助持久层进行集合的排序处理.

   集合中进行排序的核心比较器是Comparable或是Comparator,两个接口中都需要实现比较的方法进而进行排序处理,下文按照最常用的Comparator进行说明.

   梳理平常的业务处理类型,需要排序的集合元素主体最常见的无非就是两种,一种是数字,一种是对象类型.下面按照根据不同的元素类型进行介绍排序方式.


1.集合元素为数字

ArrayList<Integer> list = new ArrayList<>();
        list.add(29);
        list.add(5);
        list.add(9);
        list.add(25);
        // 1.Collections.sort方法,默认升序排列  Collections为java.util.Collections导入.底层源码是Comparator
        Collections.sort(list); 
        System.out.println(list); // 输出内容:[5, 9, 25, 29]
        // 2.集合自带的sort方法,默认升序,参数需要传递Comparator
        list.sort((a,b)->{return a.compareTo(b);});  
        System.out.println(list); // 输出内容:[5, 9, 25, 29]
        // 以上也可以简写成如下:
        list.sort(Integer::compareTo);  
        System.out.println(list); // 输出内容:[5, 9, 25, 29]
        // 如果想按照倒叙进行排列,可以修改两个形参的位置
        list.sort((a,b)->{return b.compareTo(a);});  
        System.out.println(list); // 输出内容:[5, 9, 25, 29]
        // 也可以Comparator.comparing().reversed()进行倒序排列
        list.sort(Comparator.comparing(Integer::intValue).reversed());  
        System.out.println(list); // 输出内容:[5, 9, 25, 29]


2.集合元素为对象

List<Student> studentList = Arrays.asList(
                new Student("小黄", 20),
                new Student("小花", 50),
                new Student("小李", 10)
        );
        // 默认升序
        studentList.sort(Comparator.comparing(Student::getAge));
        System.out.println(studentList);  // [Student{name='小李', age=10}, Student{name='小黄', age=20}, Student{name='小花', age=50}]
        // 调用reversed()进行降序处理
        studentList.sort(Comparator.comparing(Student::getAge).reversed());
        System.out.println(studentList);   // [Student{name='小花', age=50}, Student{name='小黄', age=20}, Student{name='小李', age=10}]


另外推荐一下stream的写法,注意jdk1.8以及以上版本可用.

List<Student> studentList = Arrays.asList(
                new Student("小黄", 20),
                new Student("小花", 50),
                new Student("小李", 10)
        );
        // 默认升序
       List<Student> studentListAfterSort = studentList.stream().sorted(Comparator.comparing(Student::getAge)).collect(Collectors.toList());
        System.out.println(studentListAfterSort);  // [Student{name='小李', age=10}, Student{name='小黄', age=20}, Student{name='小花', age=50}]
  // 调用reversed进行降序处理
        List<Student> studentListAfterSort = studentList.stream().sorted(Comparator.comparing(Student::getAge).reversed()).collect(Collectors.toList());
        System.out.println(studentListAfterSort);  // [Student{name='小花', age=50}, Student{name='小黄', age=20}, Student{name='小李', age=10}]

   stream写法在进行集合排序处理时需要注意:如果对pageHelper查询出的数据进行stream方式排序处理,会造成分页失效问题,具体内容参考:

stream排序导致pageHelper分页失效处理,

所以平常在使用时需要权衡使用哪种排序方式.

   以上是平常处理集合排序常用的几种方式,如果感觉不错或是有帮助,欢迎评论区留言或是点赞!


相关文章
|
21天前
|
存储 安全 Java
Java 集合框架中的老炮与新秀:HashTable 和 HashMap 谁更胜一筹?
嗨,大家好,我是技术伙伴小米。今天通过讲故事的方式,详细介绍 Java 中 HashMap 和 HashTable 的区别。从版本、线程安全、null 值支持、性能及迭代器行为等方面对比,帮助你轻松应对面试中的经典问题。HashMap 更高效灵活,适合单线程或需手动处理线程安全的场景;HashTable 较古老,线程安全但性能不佳。现代项目推荐使用 ConcurrentHashMap。关注我的公众号“软件求生”,获取更多技术干货!
39 3
|
2月前
|
消息中间件 Java Kafka
在Java中实现分布式事务的常用框架和方法
总之,选择合适的分布式事务框架和方法需要综合考虑业务需求、性能、复杂度等因素。不同的框架和方法都有其特点和适用场景,需要根据具体情况进行评估和选择。同时,随着技术的不断发展,分布式事务的解决方案也在不断更新和完善,以更好地满足业务的需求。你还可以进一步深入研究和了解这些框架和方法,以便在实际应用中更好地实现分布式事务管理。
|
2月前
|
Java
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
100 9
|
2天前
|
存储 Java 索引
Java快速入门之数组、方法
### Java快速入门之数组与方法简介 #### 一、数组 数组是一种容器,用于存储同种数据类型的多个值。定义数组时需指定数据类型,如`int[]`只能存储整数。数组的初始化分为静态和动态两种: - **静态初始化**:直接指定元素,系统自动计算长度,如`int[] arr = {1, 2, 3};` - **动态初始化**:手动指定长度,系统给定默认值,如`int[] arr = new int[3];` 数组访问通过索引完成,索引从0开始,最大索引为`数组.length - 1`。遍历数组常用`for`循环。常见操作包括求和、找最值、统计特定条件元素等。
|
12天前
|
Java 程序员
Java 排序神器:Comparable 和 Comparator 该怎么选?
嗨,大家好,我是小米!今天和大家聊一聊Java社招面试中常考的经典问题——Comparable和Comparator的区别。Comparable定义对象的自然排序,适用于单一固定的排序规则;Comparator则是策略接口,用于定义自定义排序规则,适用于多样化或多变的排序需求。掌握这两者的区别是理解Java排序机制的基础,也是面试中的加分题。结合实际项目场景深入探讨它们的应用,能更好地打动面试官。如果你觉得有帮助,欢迎点赞、收藏、分享,期待你的一键三连!我们下期见~ 我是小米,一个喜欢分享技术的程序员,关注我的微信公众号“软件求生”,获取更多技术干货!
42 20
|
1月前
|
存储 缓存 安全
Java 集合江湖:底层数据结构的大揭秘!
小米是一位热爱技术分享的程序员,本文详细解析了Java面试中常见的List、Set、Map的区别。不仅介绍了它们的基本特性和实现类,还深入探讨了各自的使用场景和面试技巧,帮助读者更好地理解和应对相关问题。
49 5
|
2月前
|
存储 缓存 安全
Java 集合框架优化:从基础到高级应用
《Java集合框架优化:从基础到高级应用》深入解析Java集合框架的核心原理与优化技巧,涵盖列表、集合、映射等常用数据结构,结合实际案例,指导开发者高效使用和优化Java集合。
56 4
|
2月前
|
安全 Java 开发者
Java中WAIT和NOTIFY方法必须在同步块中调用的原因
在Java多线程编程中,`wait()`和`notify()`方法是实现线程间协作的关键。这两个方法必须在同步块或同步方法中调用,这一要求背后有着深刻的原因。本文将深入探讨为什么`wait()`和`notify()`方法必须在同步块中调用,以及这一机制如何确保线程安全和避免死锁。
60 4
|
2月前
|
Java
深入探讨Java中的中断机制:INTERRUPTED和ISINTERRUPTED方法详解
在Java多线程编程中,中断机制是协调线程行为的重要手段。了解和正确使用中断机制对于编写高效、可靠的并发程序至关重要。本文将深入探讨Java中的`Thread.interrupted()`和`Thread.isInterrupted()`方法的区别及其应用场景。
83 4
|
2月前
|
Java 数据处理 数据安全/隐私保护
Java处理数据接口方法
Java处理数据接口方法
32 1