当前位置: 首页 > news >正文

【JAVA】Hutool CollUtil.sort 方法:多场景下的排序解决方案

在 Java 开发中,集合的排序是常见需求。Hutool 库的 CollUtil.sort 方法提供了一系列用于排序的实用功能,适用于不同的场景。以下是对几种常见场景及其实现方式的总结:

<dependency><groupId>org.dromara.hutool</groupId><artifactId>hutool-all</artifactId><version>6.0.0-M14</version>
</dependency>

1. 默认升序排序

对于简单的升序排序,可以直接使用 CompareUtil.natural 获取自然顺序比较器,并结合 CollUtil.sort 方法实现:

List < String > list = ListUtil.of("banana", "apple", "orange");
List < String > sortedList = CollUtil.sort(list, CompareUtil.natural());

2. 默认降序排序

如果需要进行降序排序,可以结合 CompareUtil.naturalReverse 获取逆序比较器,并使用 CollUtil.sort 方法进行排序:

List < String > list = ListUtil.of("banana", "apple", "orange");
List < String > sortedList = CollUtil.sort(list, CompareUtil.naturalReverse());

3. 字符串长度排序逻辑

当需要基于自定义逻辑进行排序时,可以使用 Hutool 提供的 StrLengthComparator 等已定义的比较器,或者通过以下方式自定义比较器:

List < String > list = ListUtil.of("banana", "apple", "orange");
// 短在前
List < String > sortedList = CollUtil.sort(list, StrLengthComparator.INSTANCE);
// 短在后
List < String > sortedList2 = CollUtil.sort(list, StrLengthComparator.INSTANCE.reversed());

4. 带有null值排序

当集合中包含 null 值时,可以使用 Comparator.nullsLastComparator.nullsFirst 方法将 null 值排序到列表的一端:

List < String > list = ListUtil.of(null, "banana", "apple", "orange");
List < String > sortedList = CollUtil.sort(list, Comparator.nullsLast(Comparator.naturalOrder()));
System.out.println(sortedList);

或者

List < String > list = ListUtil.of("banana", "apple", "orange", null);
List < String > sortedList = CollUtil.sort(list, Comparator.nullsFirst(Comparator.naturalOrder()));
System.out.println(sortedList);

5. 对象字段排序

对于对象集合的排序,可以使用 FieldsComparator 或其他比较器对多个字段进行排序:

List < Person > people = ListUtil.of(new Person("Alice", null),new Person("Bob", 28),new Person("Charlie", 25));
List < Person > sorted = CollUtil.sort(people, new FieldComparator<>(Person.class, "age"));
System.out.println(sorted);

或者CompareUtil实现排序逻辑:

List < Person > people = ListUtil.of(new Person("Alice", null), new Person("Bob", 25),new Person("Charlie", 25));
// 自然比较两个对象的大小,isNullGreater – null值是否做为最大值
List < Person > sort = CollUtil.sort(people,(compareOne, compareTow) -> CompareUtil.compare(compareOne.getAge(), compareTow.getAge(), true));
System.out.println(sort);

年龄相同按照姓名排序

List < Person > people = ListUtil.of(new Person("Alice", null),new Person("Bob", 25),new Person("Charlie", 25));
List < Person > sorted2 = CollUtil.sort(people, new FieldsComparator<>(Person.class, "age", "name"));
System.out.println(sorted2);

总结:
Hutool 的 CollUtil.sort 方法为 Java 开发者提供了一系列强大的排序功能,能够满足各种场景下的排序需求。通过合理选择和使用这些功能,可以显著提高代码的可读性和可维护性。

http://www.lryc.cn/news/405932.html

相关文章:

  • Mysql-安装(Linux)
  • 如何查看日志
  • python实现责任链模式
  • Prometheus监控ZooKeeper
  • vuepress搭建个人文档
  • 面试题 17.14.最小K个数
  • C++实现LRU缓存(新手入门详解)
  • 汇昌联信数字做拼多多运营实力好吗?
  • 【云原生】Prometheus 服务自动发现使用详解
  • (十九)原生js案例之h5地里位置信息与高德地图的初使用
  • 三、基础语法2(30小时精通C++和外挂实战)
  • gitee设置ssh公钥密码频繁密码验证
  • BGP选路之Next Hop
  • 牛客14666(优先屏障) + 牛客14847(Masha与老鼠)
  • Git下载与安装
  • 创建vue2/vue3项目
  • IOS七层模型对应的网络协议和物理设备
  • 论文复现:Predictive Control of Networked Multiagent Systems via Cloud Computing
  • JSON 文件存储
  • python——pynput
  • [用AI日进斗金系列]用码上飞在企微接单开发一个项目管理系统!
  • 《JavaEE篇》--多线程(2)
  • 防爆智能手机如何助力电气行业保驾护航?
  • 24.7.24数组|那几个课后得做的题
  • 03Spring底层架构核心概念解析
  • Vue学习---vue 防抖处理函数,是处理什么场景
  • 力扣爆刷第166天之TOP100五连刷96-100(单词拆分、回溯、旋转数组)
  • 2024在线PHP加密网站源码
  • 网络驱动移植(RTL8189)
  • go语言中map学习