Arrays工具类提供排序、查找、比较、填充和复制等操作,提升开发效率。1. sort()支持基本类型和对象数组排序,对象数组可结合Comparator实现降序;2. binarySearch()需在有序数组上执行,否则结果不可预测,查找失败返回负值表示插入点;3. equals()比较一维数组内容,deepEquals()用于多维数组深度比较;4. fill()可全量或范围填充数组;5. copyOf()和copyOfRange()简化数组复制。注意使用前提如排序状态和引用类型匹配,避免误用。

Java中的Arrays工具类位于java.util包中,提供了大量静态方法用于数组的常见操作,如排序、查找、填充、比较等。合理使用Arrays能显著提升开发效率并减少出错概率。以下是实际开发中常用的Arrays操作技巧与实践建议。
数组排序:使用sort()方法
Arrays.sort() 是最常用的方法之一,支持基本类型数组和对象数组的排序。
对于基本类型(如int、double),默认按升序排列:
int[] numbers = {5, 2, 8, 1};Arrays.sort(numbers); // 结果:[1, 2, 5, 8]
对于对象数组(如String或自定义对象),需实现Comparable接口或传入Comparator:
立即学习“Java免费学习笔记(深入)”;
String[] names = {"Alice", "Bob", "Charlie"};Arrays.sort(names); // 按字典序排序
若要降序排序,可结合Comparator.reverseOrder():
Arrays.sort(nums, Comparator.reverseOrder()); // [4, 3, 1]
注意:基本类型包装类数组才能使用Comparator,int[]不行,应使用Integer[]。
数组查找:配合排序使用binarySearch()
Arrays.binarySearch() 使用二分查找算法,效率高,但要求数组必须已排序。
未排序数组直接调用会导致结果不可预测。
int[] sortedArr = {1, 3, 5, 7};int index = Arrays.binarySearch(sortedArr, 5); // 返回2
int notFound = Arrays.binarySearch(sortedArr, 6); // 返回负值
如果查找失败,返回值为 -(插入点) - 1,可用于判断元素应插入的位置。
实践中建议先排序再搜索:
Arrays.sort(data);int pos = Arrays.binarySearch(data, target);
数组内容比较:使用equals()方法
直接使用==比较数组引用,无法比较内容。应使用Arrays.equals()。
int[] b = {1, 2, 3};
boolean isEqual = Arrays.equals(a, b); // true
对于多维数组,使用Arrays.deepEquals()进行深度比较:
int[][] arr1 = {{1,2}, {3,4}};int[][] arr2 = {{1,2}, {3,4}};
boolean deepEqual = Arrays.deepEquals(arr1, arr2); // true
数组填充与复制
Arrays.fill() 可快速将数组所有元素设为指定值,常用于初始化。
int[] arr = new int[5];Arrays.fill(arr, 7); // [7, 7, 7, 7, 7]
也可指定范围填充:
Arrays.fill(arr, 1, 4, 9); // 索引1到3设为9数组复制推荐使用Arrays.copyOf() 或 copyOfRange():
int[] src = {1, 2, 3, 4};int[] copy = Arrays.copyOf(src, src.length);
int[] part = Arrays.copyOfRange(src, 1, 3); // [2, 3]
相比System.arraycopy(),这些方法更简洁易用。
基本上就这些。掌握Arrays常用方法,能在处理数组时写出更清晰、高效的代码。关键是注意方法的适用条件,比如排序前提、类型限制等,避免误用。










