登录
首页 >  文章 >  java教程

Arrays.sort 排序对象数组详解

时间:2026-05-12 18:47:27 461浏览 收藏

Java中Arrays.sort对对象数组排序并非开箱即用,必须通过实现Comparable接口或传入Comparator明确排序规则,否则将抛出ClassCastException;其中Comparator更灵活,支持Lambda简洁写法、多字段链式排序(如先状态升序再时间降序)、null安全处理及避免耗时操作等关键实践;同时需警惕原始类型数组(如int[])与包装类数组(如Integer[])底层算法差异,以及浮点数比较、时间戳精度等隐性陷阱——真正决定排序稳定性的,往往不是语法是否正确,而是比较逻辑是否严格满足自反性、对称性和传递性。

如何使用 Arrays.sort 方法对存储业务数据的对象数组进行排序

Arrays.sort 不能直接对任意对象数组排序,必须明确告诉它“按什么排”——要么让对象实现 Comparable,要么传入 Comparator。否则会抛 ClassCastException

对象没实现 Comparable,又不想改类定义?用 Comparator

这是最常见也最灵活的做法。比如有个订单类 Order,想按金额降序排:

Arrays.sort(orders, (a, b) -> Double.compare(b.amount, a.amount));

注意三点:

  • lambda 中参数类型由数组元素类型自动推导,不用写 Order a, Order b
  • 升序用 Double.compare(a.amount, b.amount),降序就调换位置
  • 如果 amount 可能为 null,别直接用 .compareTo(),改用 Double.compare()Comparator.nullsLast()

多个字段组合排序:链式调用 thenComparing

比如先按状态(status)升序,状态相同时按创建时间(createdAt)降序:

Arrays.sort(orders, Comparator.comparing(Order::getStatus)
    .thenComparing(Order::getCreatedAt, Comparator.reverseOrder()));

关键细节:

  • Comparator.comparing() 默认处理 null 值时抛 NullPointerException
  • 需要容错时,显式加 Comparator.nullsFirst()Comparator.nullsLast()
  • 不要在 lambda 里做耗时操作(如数据库查询),sort 内部会多次调用比较逻辑

原始类型数组和包装类数组行为不同

别混淆:int[]Integer[] 调用的是完全不同的 sort 重载方法:

  • int[] arr = {3,1,2}; Arrays.sort(arr); → 走原生快排,高效
  • Integer[] arr = {3,1,2}; Arrays.sort(arr); → 走 TimSort,依赖 compareTo 或传入 Comparator
  • 如果误把 int[] 当成对象数组传给带 Comparator 的版本,编译直接报错

真正容易出问题的不是语法,而是比较逻辑本身是否满足“自反性、对称性、传递性”。比如用浮点数做精确相等判断、用系统时间戳当排序依据却忽略纳秒精度差异——这些不会报错,但排序结果会不稳定。

终于介绍完啦!小伙伴们,这篇关于《Arrays.sort 排序对象数组详解》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>