Java List.toArray方法:为什么传入数组长度大于List大小时,只有第一个空余元素被置为null?(第一个.空余.数组.传入.大于...)
java list.toarray() 方法详解:为什么传入数组长度大于 list 大小时,只有第一个空余元素被置为 null?
本文深入探讨 Java 中 List.toArray() 方法的行为,特别是当传入的数组长度大于 List 大小时的特殊情况。
我们来看一个例子:
List<Integer> list = List.of(12, 34, 56); Integer[] array = list.toArray(new Integer[]{1, 2, 1, 43, 32, 1}); System.out.println(Arrays.toString(array));
这段代码的输出结果是 [12, 34, 56, null, 32, 1],并非预期的 [12, 34, 56, null, null, null]。这是因为 List.toArray(T[] a) 方法的实现机制。
根据官方文档,如果传入的数组 a 长度大于 List 的大小,则紧随 List 元素之后的第一个元素会被设置为 null,其余元素保持不变。
让我们分析 ArrayList 的源码 (部分代码片段):
@SuppressWarnings("unchecked") public <T> T[] toArray(T[] a) { int size = size(); if (a.length < size) // Make a new array of a's runtime type, but my contents: return (T[]) Arrays.copyOf(elementData, size, a.getClass()); System.arraycopy(elementData, 0, a, 0, size); if (a.length > size) a[size] = null; return a; }
这段代码清晰地表明,当 a.length > size 时,只有 a[size] (紧随 List 元素后的第一个元素) 被设置为 null。 List.of() 创建的不可变列表的实现也遵循类似的逻辑。
因此,在例子中,[12, 34, 56] 之后,只有第四个元素被设置为 null,其余元素保留了原数组的值。 这种设计避免了不必要的内存分配,并允许用户通过检查第一个 null 元素来确定 List 的实际大小,前提是 List 本身不包含 null 值。 这是一种效率优先的设计选择。
以上就是Java List.toArray方法:为什么传入数组长度大于List大小时,只有第一个空余元素被置为null?的详细内容,更多请关注知识资源分享宝库其它相关文章!