
本文介绍使用 `arrays.sort()` 配合 `comparator` 链式调用,对 int 类型二维数组按多字段(如先第 0 列、再第 1 列)进行稳定升序排序的简洁高效方法。
在 Java 中,对二维数组(如 int[][] arr)按多个维度排序,核心思路是将每行视为一个逻辑“记录”,通过 Comparator
以下是完整可运行示例:
import java.util.Arrays;
import java.util.Comparator;
public class MultiColumnSort {
public static void main(String[] args) {
int[][] arr = {
{1, 7},
{2, 6},
{3, 9},
{4, 1},
{5, 3},
{6, 7}
};
// 按第 0 列升序 → 相等时按第 1 列升序
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(...) 显式指定泛型类型,避免类型推断失败; - thenComparing(...) 支持链式扩展,可继续添加 .thenComparing(...) 实现三列及以上排序;
- 所有比较器操作均原地排序,不创建新数组;
- 若需降序,可用 comparingInt(...).reversed() 或 thenComparingInt(...).reversed();
- 注意:每行必须非 null,否则运行时抛 NullPointerException;建议在排序前校验数据完整性。
该方法简洁、安全、符合 Java 8+ 最佳实践,适用于绝大多数多字段二维数组排序场景。
立即学习“Java免费学习笔记(深入)”;










