登录
首页 >  文章 >  java教程

Java二维数组多列排序技巧

时间:2026-02-25 23:00:52 299浏览 收藏

本文深入浅出地讲解了如何在 Java 中高效实现二维数组的多列排序——利用 `Arrays.sort()` 结合函数式风格的 `Comparator` 链式调用(如 `comparingInt().thenComparing()`),轻松完成按第 0 列主序、第 1 列次序的稳定升序排列,代码简洁、原地操作、可无限扩展至三列及以上,同时兼顾类型安全与运行健壮性,是 Java 8+ 环境下处理多字段二维数据排序的首选实践方案。

如何在 Java 中对二维数组按多列进行升序排序(先按第一列,再按第二列)

本文介绍使用 `Arrays.sort()` 配合 `Comparator` 链式调用,对 int 类型二维数组按多字段(如先第 0 列、再第 1 列)进行稳定升序排序的简洁高效方法。

在 Java 中,对二维数组(如 int[][] arr)按多个维度排序,核心思路是将每行视为一个逻辑“记录”,通过 Comparator 定义比较规则。推荐使用函数式编程风格的链式比较器:先基于第一列(arr[i][0])主排序,当第一列相等时,再依据第二列(arr[i][1])次排序。

以下是完整可运行示例:

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.<int[]>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二维数组多列排序技巧》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!

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