Arrays.copyOf()与System.arraycopy() 认识

Talk is cheap , Show me the code.

基本用法

最近在看jdk源码,这两个方法经常出现,用来复制一个新的数组,所以自己总结一下。

Arrays.copyOf()

语法

public static <T> T[] copyOf(T[] original,int newLength)

Parameters:
original  被复制的数组
newLength 新数组的长度

Returns:
被复制的数组,如果newLength比 original.length大,就用null来填充

Throws:
NegativeArraySizeException  如果newLength是负数就抛出该异常
NullPointerException  如果original是null就抛出该异常

这是一个泛型方法,泛型可以理解成一个模板方法,各种类型的方法可以套用这个模板,成为实例。
比如:

public static byte[] copyOf(byte[] original, int newLength)public static short[] copyOf(short[] original, int newLength) ;
public static int[] copyOf(int[] original, int newLength);

我们来看看里面具体的方法(源码是jdk1.8)

public static <T> T[] copyOf(T[] original, int newLength) {
        return (T[]) copyOf(original, newLength, original.getClass());
    }

public static <T,U> T[] copyOf(U[] original, int newLength, Class<? extends T[]> newType) {       
        //未经检查的警告。就是告诉编译器,这是合法的事,让它别管
        @SuppressWarnings("unchecked")  
        //三元运算符,如果newType 是Object[] 类型的,就直接强制转换成newLength大小的T[]类型数组,不是Object[]类型的,就利用反射新建T[]类型数组
       // 非数组类型是不能通过getComponentType()方法获得元素的Class对象类型
        T[] copy = ((Object)newType == (Object)Object[].class)
            ? (T[]) new Object[newLength]
            : (T[]) Array.newInstance(newType.getComponentType(), newLength);
            
         // 这里也是用到System.arraycopy(),下面说一下它的语法
        System.arraycopy(original, 0, copy, 0,
                         Math.min(original.length, newLength));
        return copy;
    }

System.arraycopy()

语法

 public static native void arraycopy(Object src,  int  srcPos,
                                        Object dest, int destPos,
                                        int length);
  Parameters:
  src  原数组
  srcPos 从原数组开始的地方
  dest  新数组,就是从原数组中复制后存储的地方
  destPos 从新数组开始的地方
  length  要复制的数量
  其实就是从srcPos到srcPos+length-1 复制到 desPos到desPos+length-1 位置
  为啥减1,因为数组的位置从0开始
   
   Throws:
   IndexOutOfBoundsException 如果复制的数组元素数量大于新数组的长度,就抛出越界异常
   ArrayStoreException  如果原数组的类型和新数组的类型不一致
   NullPointerException 如果原数组或者新数组中有一个为null

好了,了解了System.arraycopy()方法后,再看到

 System.arraycopy(original, 0, copy, 0,
                         Math.min(original.length, newLength));
// 取其中的更小数                         
Math.min(original.length,newLength)
// 如果 newLength 小,就复制原数组的一部分数据
// 如果 original.length 小,与newlength相差的部分用null补充 

您可能对以下文章感兴趣
What is SuppressWarnings (“unchecked”) in Java?
Java的native方法

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章