Arrays.asList()返回固定大小列表,不支持增删;基本类型数组需用包装类;修改引用类型元素会影响原数组;Arrays.sort()按类型选择算法;equals()不适用于多维数组,应使用deepEquals()。

如何用 Arrays.asList() 安全转数组为列表
这个方法常被误以为能直接创建可变列表,实际返回的是 Arrays 内部的固定大小 List 实现,不支持 add()、remove() 等操作,调用会抛 UnsupportedOperationException。
- 仅适用于「只读」或「仅遍历」场景;需要增删改请包装成
new ArrayList(Arrays.asList(...)) - 基本类型数组(如
int[])传入后不会自动装箱,而是把整个数组当做一个元素,结果是List—— 必须用包装类数组(Integer[])才符合预期 - 该方法返回的
List与原数组仍共享引用,修改其中对象属性会影响原数组(对引用类型有效)
Arrays.sort() 的重载差异与陷阱
排序行为高度依赖参数类型和重载版本:对基本类型数组直接排序,对对象数组则要求元素实现 Comparable 或传入 Comparator,否则运行时报 ClassCastException。
-
Arrays.sort(int[])使用双轴快排(Java 7+),高效且稳定;而Arrays.sort(Object[])默认用归并排序(保证稳定性),但若传了Comparator可能退化为 TimSort - 对二维数组(如
int[][])调用sort(),默认按首元素升序排列各行,不是按行列整体排序 —— 如需按列排序,必须显式提供Comparator - 注意
sort()是原地排序,不返回新数组;若需保留原顺序,请先clone()
用 Arrays.equals() 和 Arrays.deepEquals() 判等时怎么选
普通 equals() 对一维数组比较值,对多维数组却只比较引用(因为 int[][] 是对象数组,其元素是 int[] 引用);deepEquals() 才真正递归比内容。
-
Arrays.equals(new int[]{1,2}, new int[]{1,2})→true;但Arrays.equals(new int[][]{{1}}, new int[][]{{1}})→false -
Arrays.deepEquals(new int[][]{{1}}, new int[][]{{1}})→true;但它对含null的嵌套结构也安全,而deepHashCode()遇null会返回 0 - 自定义对象数组判等,必须确保元素类重写了
equals()和hashCode(),否则deepEquals()仍可能返回false
Arrays.fill() 和 Arrays.setAll() 的适用边界
fill() 简单粗暴,所有位置设同一值;setAll() 更灵活,靠 lambda 按索引动态生成值,但要注意闭包捕获变量的线程安全性。
立即学习“Java免费学习笔记(深入)”;
-
fill()支持基本类型和对象数组,对对象数组填null合法;但若填的是可变对象(如new StringBuilder()),所有索引指向同一实例 —— 修改任一位置会影响全部 -
setAll()从 Java 8 引入,适合生成序列(如i -> i * i)、填充随机数、或根据上下文构造对象;但 lambda 中不应有副作用(如修改外部集合) - 两者都不支持部分填充,如需区间赋值,得配合
Arrays.copyOfRange()或手动循环
多维数组的深度操作、原始类型与泛型擦除的交互、以及并发环境下 Arrays 工具类的无状态特性,才是真正容易出问题的地方。










