Arrays 是 Java 中用于高效操作数组的工具类,提供 fill()、setAll() 初始化,equals() 和 deepEquals() 比较,sort() 排序,binarySearch() 查找,以及 asList() 转集合等静态方法,但不改变数组长度且需注意基本类型与集合转换限制。

Arrays 是 Java 中非常实用的工具类,位于 java.util 包下,专门用于操作数组——它不改变数组本身长度,但提供了大量静态方法,让数组的初始化、比较、查找、排序、打印、复制等操作变得简洁高效。
快速创建和初始化数组
虽然数组声明本身简单,但 Arrays 提供了 fill() 和 setAll() 方法,能批量赋值:
-
Arrays.fill(arr, value):将整个数组或指定范围设为同一值(适合布尔、数字、对象引用) -
Arrays.setAll(arr, i -> i * i):用 lambda 表达式按索引生成元素(Java 8+),比循环更函数化
数组内容的比较与判断相等性
直接用 == 或 equals() 比较数组对象,只比较引用;真正比“内容是否一致”,必须用 Arrays.equals():
-
Arrays.equals(a, b):支持基本类型和对象数组,逐元素调用equals()(对象数组要求元素自身支持) -
Arrays.deepEquals():适用于多维数组(如int[][]),递归比较每一层 - 注意:
Arrays.asList(arr)返回的 List 是固定大小的包装类,修改它可能抛UnsupportedOperationException
排序与二分查找(基于已排序前提)
Arrays.sort() 是最常用方法之一,支持多种重载:
立即学习“Java免费学习笔记(深入)”;
- 对基本类型数组使用快排或双轴快排(如
int[]) - 对对象数组默认使用 TimSort(稳定排序),也可传入
Comparator自定义规则 -
Arrays.binarySearch()要求数组已升序排列,否则结果不可预测;返回匹配索引或负数插入点
数组与集合的转换要点
常见误区是认为 Arrays.asList(arr) 能直接用于增删改——其实它返回的是 Arrays.ArrayList(非 java.util.ArrayList),底层仍绑定原数组:
- ✅ 可以
get()、set()、遍历,且修改会反映到原数组(对象数组) - ❌ 不支持
add()、remove()、clear()(抛异常) - ✅ 真正需要可变集合时,应包装为新实例:
new ArrayList(Arrays.asList(arr)) - ⚠️ 基本类型数组(如
int[])不能直接转集合——因为泛型不支持基本类型,需先转成包装类型数组(如用 Stream:Arrays.stream(arr).boxed().collect(Collectors.toList()))
掌握 Arrays 工具类的关键,在于理解它提供的不是“新容器”,而是对原生数组的安全增强。用对方法,能少写很多样板代码,也能避开集合转换中的典型陷阱。










