Arrays.asList()返回的是Arrays内部的ArrayList,不支持add/remove等结构修改操作,调用会抛出UnsupportedOperationException。

Arrays.asList() 返回的 List 为什么不能 add/remove?
因为 Arrays.asList() 返回的是 Arrays 内部的静态嵌套类 ArrayList(注意:不是 java.util.ArrayList),它底层直接引用传入的数组,不支持结构修改操作。调用 add()、remove() 或 clear() 会抛出 UnsupportedOperationException。
- 适用场景:快速将数组转为“只读视图”或用于
contains()、indexOf()等查询操作 - 若需可变集合,必须包装一层:
new ArrayList<>(Arrays.asList(arr))
- 注意:即使包装成
ArrayList,原始数组与列表仍共享元素引用——修改数组某元素,列表对应位置也会变(反之亦然)
Collections.unmodifiableXXX() 包装后修改原集合会怎样?
Collections.unmodifiableList() 等方法返回的是原集合的“不可变视图”,它本身不复制数据,只是拦截所有写操作。但关键点在于:它不阻止你通过原始引用去修改底层集合。
- 示例:先
List,再raw = new ArrayList(); List,此时调用unmod = Collections.unmodifiableList(raw); unmod.add("x")报错,但raw.add("x")仍成功,且unmod随之可见新元素 - 真正安全的不可变集合应使用
java.util.ImmutableCollections(Java 10+ 的List.of()、Set.copyOf()等),它们内部深拷贝或构造即冻结 -
Collections.unmodifiableXXX()适合临时封装、防止误调用,但不提供线程安全或数据隔离保障
Arrays.sort() 和 Collections.sort() 底层是否共用同一套算法?
是的,但仅限于对象数组/集合。Java 7+ 中两者都基于 **Timsort**(一种稳定、适应性强的归并+插入混合排序),时间复杂度平均 O(n log n),最坏也是 O(n log n);而基本类型数组(如 int[])用的是经过高度优化的双轴快排(Dual-Pivot Quicksort)。
Android 是一个专门针对移动设备的软件集,它包括一个操作系统,中间件和一些重要的应用程序。Beta版的 Android SDK 提供了在Android平台上使用JaVa语言进行Android应用开发必须的工具和API接口。 特性 应用程序框架 支持组件的重用与替换 Dalvik 虚拟机 专为移动设备优化 集成的浏览器 基于开源的WebKit 引擎 优化的图形库 包括定制的2D图形库,3D图形库基于
-
Arrays.sort(Object[])和Collections.sort(List)实际都调用同一个Timsort.sort()方法 -
区别在于:后者会先把
List转成 Object 数组再排序,再逐个写回——所以对ArrayList效率接近直接排序数组;但对LinkedList,这种“转数组→排序→写回”开销明显,应避免 - 自定义比较逻辑时,优先复用同一个
Comparator实例,避免重复创建(尤其在循环中)
什么时候该用 Arrays,什么时候该用 Collections?
看输入源头和操作目标。核心分界线是:**数组 vs. Collection 接口实现类**。
立即学习“Java免费学习笔记(深入)”;
- 处理
int[]、String[]等数组时,用Arrays:如Arrays.toString()、Arrays.binarySearch()、Arrays.copyOf() - 处理
List、Set、Map等接口实例时,用Collections:如Collections.synchronizedList()、Collections.emptySet()、Collections.frequency() - 交叉场景要小心:比如想给
String[]排序后转成不可变List,应分两步——先Arrays.sort(arr),再Collections.unmodifiableList(Arrays.asList(arr));不要试图对Arrays.asList()结果直接调Collections.sort()(虽然能工作,但易误解语义)
Collections.synchronizedList(),遍历仍需手动同步;而 Arrays 所有方法都是纯内存操作,无任何锁机制。多线程下,优先考虑 java.util.concurrent 包中的集合类型。









