上一篇                     
               
			  Java如何给数组排序?
- 后端开发
- 2025-06-20
- 3850
 Java中可使用
 
 
Arrays.sort()方法对数组排序,默认升序排列,对于基本类型数组(如int、double),使用快速排序算法;对于对象数组(如String、自定义类),使用归并排序或TimSort算法,也可通过
 Comparator自定义排序规则实现降序等需求。
在Java中给数组排序有多种高效且灵活的方式,以下是详细方法和实践建议:
使用 Arrays.sort() 方法(最常用)
 
适用场景:快速对基本类型或对象数组排序
代码示例:
import java.util.Arrays;
// 1. 基本类型数组(如int)
int[] numbers = {5, 3, 9, 1};
Arrays.sort(numbers); // 升序排序
System.out.println(Arrays.toString(numbers)); // 输出 [1, 3, 5, 9]
// 2. 对象数组(如String)
String[] names = {"John", "Alice", "Bob"};
Arrays.sort(names); // 按字典序升序
System.out.println(Arrays.toString(names)); // 输出 [Alice, Bob, John]
// 3. 自定义排序规则(通过Comparator)
Integer[] nums = {10, 5, 8};
Arrays.sort(nums, (a, b) -> b - a); // 降序排序
System.out.println(Arrays.toString(nums)); // 输出 [10, 8, 5] 
特点:
- 时间复杂度:平均 O(n log n)(使用双轴快速排序或归并排序)
- 原地排序(直接修改原数组)
- 对象数组需实现 Comparable接口,否则需提供Comparator
使用 Collections.sort()(针对List集合)
 
适用场景:对 ArrayList 等List集合排序
代码示例:

import java.util.ArrayList; import java.util.Collections; ArrayList<Integer> list = new ArrayList<>(); list.add(30); list.add(10); list.add(20); Collections.sort(list); // 升序排序 System.out.println(list); // 输出 [10, 20, 30] // 自定义排序 Collections.sort(list, Collections.reverseOrder()); // 降序
Java 8 Stream API(函数式编程)
适用场景:需链式操作或生成新数组时
代码示例:
import java.util.Arrays;
int[] arr = {7, 2, 5};
// 升序排序并生成新数组
int[] sortedArr = Arrays.stream(arr)
                        .sorted()
                        .toArray();
System.out.println(Arrays.toString(sortedArr)); // 输出 [2, 5, 7]
// 对象数组自定义排序
String[] languages = {"Java", "Python", "C++"};
String[] sortedLangs = Arrays.stream(languages)
                             .sorted((s1, s2) -> s2.length() - s1.length()) // 按字符串长度降序
                             .toArray(String[]::new); 
手动实现排序算法(理解原理)
示例:快速排序(实际开发建议用内置方法)
public static void quickSort(int[] arr, int low, int high) {
    if (low < high) {
        int pivot = partition(arr, low, high);
        quickSort(arr, low, pivot - 1);
        quickSort(arr, pivot + 1, high);
    }
}
private static int partition(int[] arr, int low, int high) {
    int pivot = arr[high];
    int i = low - 1;
    for (int j = low; j < high; j++) {
        if (arr[j] < pivot) {
            i++;
            swap(arr, i, j);
        }
    }
    swap(arr, i + 1, high);
    return i + 1;
}
private static void swap(int[] arr, int i, int j) {
    int temp = arr[i];
    arr[i] = arr[j];
    arr[j] = temp;
} 
方法对比与最佳实践
| 方法 | 优势 | 局限性 | 
|---|---|---|
| Arrays.sort() | 高效、简洁,支持并行排序 | 修改原数组 | 
| Collections.sort() | 专为List优化 | 仅适用于集合类型 | 
| Stream API | 链式操作、生成新数组,适合复杂逻辑 | 性能略低于直接排序 | 
| 手动实现算法 | 灵活控制逻辑,学习用途 | 易出错,实际开发不推荐 | 
最佳实践:

- 优先使用内置方法:Arrays.sort()和Collections.sort()经过高度优化。
- 对象排序规则: 
  - 实现 Comparable接口定义自然顺序
- 使用 Comparator实现动态排序(如Comparator.comparing(Person::getAge))
 
- 实现 
- 稳定性要求:对象排序默认稳定(相等元素顺序不变),基本类型不稳定。
- 大数据量优化:用 Arrays.parallelSort()并行排序(Java 8+)。
常见问题
Q:如何对二维数组排序?
int[][] matrix = {{2,5}, {1,9}, {3,4}};
Arrays.sort(matrix, (a, b) -> a[0] - b[0]); // 按第一列升序 
Q:如何避免修改原数组?
int[] original = {6, 2, 4};
int[] copy = Arrays.copyOf(original, original.length);
Arrays.sort(copy); // 原数组不受影响 
Java数组排序的核心是 Arrays.sort(),它覆盖了大多数场景,对于集合类型使用 Collections.sort(),函数式处理选择Stream API,自定义排序通过 Comparator 实现,避免重复造轮子,实际开发中,内置方法在性能和稳定性上远优于手动实现。

引用说明基于Oracle官方Java文档(Arrays类)及《Java核心技术 卷I》第14章,遵循Java 17规范,算法复杂度参考《算法导论》第三版。
 
  
			