
本文介绍如何使用 java 的 `arrays.sort()` 配合 `comparator` 链式调用,对 int 类型二维数组按主次优先级(如先按第 0 列升序,再按第 1 列升序)进行稳定排序。
在 Java 中,对二维数组(如 int[][] arr)按多个维度排序,核心在于将每一行视为一个整体元素,并通过自定义 Comparator 定义复合排序逻辑。推荐方式是利用 Comparator.
以下为完整示例代码:
import java.util.*;
public class MultiColumnSort {
public static void main(String[] args) {
int[][] arr = {
{1, 7},
{2, 6},
{3, 9},
{4, 1},
{5, 3},
{6, 7}
};
// 先按第 0 列(col1)升序,再按第 1 列(col2)升序
Arrays.sort(arr, Comparator.comparingInt(row -> row[0])
.thenComparing(row -> row[1]));
System.out.println(Arrays.deepToString(arr));
// 输出:[[1, 7], [2, 6], [3, 9], [4, 1], [5, 3], [6, 7]]
}
} ✅ 关键说明:
- Comparator.
comparingInt(...) 显式指定泛型类型,避免类型推断失败; - row -> row[0] 提取第一列作为主排序键(int 类型,故用 comparingInt 提升性能);
- thenComparing(row -> row[1]) 在主键相等时,按第二列升序比较(自动适配 int,也可显式写为 thenComparingInt(row -> row[1]));
- 排序是原地修改,不创建新数组,注意备份原始数据(如需保留)。
⚠️ 注意事项:
立即学习“Java免费学习笔记(深入)”;
- 若某行可能为 null,需在 lambda 中增加空值检查,或改用 Comparator.nullsFirst(...);
- 如需降序,可用 reversed()(如 .comparingInt(...).reversed())或 thenComparingInt(...).reversed();
- 此方法仅适用于 Object 类型数组的排序(int[][] 是 Object 类型,因 int[] 是对象),不适用于基本类型一维数组(如 int[])。
掌握 Comparator 链式组合,可轻松扩展至三列及以上排序(如 .thenComparing(...).thenComparing(...)),是 Java 函数式排序的最佳实践。










