本文介绍使用 `arrays.sort()` 配合 `comparator` 链式调用,对 int 类型二维数

在 Java 中,对二维数组(如 int[][])按多个维度排序,核心思路是将每行视为一个整体元素,并通过自定义 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]]
}
} ✅ 关键说明:
comparingInt(row -> row[0]).thenComparing(row -> row[1]).reversed() // 全局逆序 comparingInt(row -> row[0]).thenComparingInt(row -> -row[1]) // 仅 col2 降序
⚠️ 注意事项:
掌握这种链式 Comparator 写法,不仅能处理二维数组多级排序,还可轻松扩展至三列及以上(连续调用 thenComparing),是 Java 函数式排序的典型实践。