参考链接: Java中的Array vs ArrayList
先看一个小的代码片段
ArrayList<Integer> arrayList = new ArrayList<>();
Collections.addAll(arrayList, 11, 21, 31, 41, 51);
Integer[] a = new Integer[0];
Integer[] b = new Integer[arrayList.size()];
Integer[] toArray = arrayList.toArray(a);
System.err.println(Arrays.toString(toArray));
Integer[] toArray1 = arrayList.toArray(b);
System.err.println("a = "+Arrays.toString(a) +" , b="+Arrays.toString(b));
System.err.println("xxx "+(Arrays.equals(toArray, toArray1))); // true
一般在需要将List转成Array的时候,都是调用 Bean arr[] = list.toArray(new Bean[0]);这样的一句代码去完成的。
但是,稍微看一下就会有点奇怪,为什么传入的参数是 new Bean[0] ,而不是 new Bean[list.size()] ?
其中两种情况下返回的值是相同的。!
but why ???
// java.util.ArrayList#toArray(T[])
public <T> T[] toArray(T[] a) {
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;
}
源码写的清清楚楚了,就是如果当前传入的数组的长度小于当前list的长度,就直接返回一个新的数组。
而如果传入的数组长度大于list长度,前面的复制进来了。数组后面的元素从size开始,都是 null 了。