/*** Copies the specified array, truncating or padding with nulls (if necessary) //~ 1. 切断或用 null 填充以保证长度为 newLength* so the copy has the specified length. For all indices that are* valid in both the original array and the copy, the two arrays will* contain identical values. For any indices that are valid in the* copy but not the original, the copy will contain <tt>null</tt>.* Such indices will exist if and only if the specified length* is greater than that of the original array.* The resulting array is of the class <tt>newType</tt>. //~ 2. 返回 newType 类型的数组** @param <U> the class of the objects in the original array* @param <T> the class of the objects in the returned array* @param original the array to be copied* @param newLength the length of the copy to be returned* @param newType the class of the copy to be returned* @return a copy of the original array, truncated or padded with nulls* to obtain the specified length* @throws NegativeArraySizeException if <tt>newLength</tt> is negative* @throws NullPointerException if <tt>original</tt> is null* @throws ArrayStoreException if an element copied from* <tt>original</tt> is not of a runtime type that can be stored in* an array of class <tt>newType</tt>* @since 1.6*/public static <T,U> T[] copyOf(U[] original, int newLength, Class<? extends T[]> newType) {@SuppressWarnings("unchecked")T[] copy = ((Object)newType == (Object)Object[].class)? (T[]) new Object[newLength]: (T[]) Array.newInstance(newType.getComponentType(), newLength);System.arraycopy(original, 0, copy, 0,Math.min(original.length, newLength));return copy;}
此方法返回一个新的数组, 长度为 newLength, 如果新的长度比原来的长, 则会填充 null(基本数据类型填充默认值).
此方法是浅拷贝, 根本使用的还是 System.arraycopy(), 而 System.arraycopy() 本身也是浅拷贝.
