Arrays.copyOf(...)和System.arraycopy(...)

首先观察先System.arraycopy(Object src, int srcPos, Object dest, int destPos, int length)的声明:

[java]  view plain copy print ?
  1. public staticnativevoid arraycopy(Object src, int  srcPos, 
  2.                                         Object dest, int destPos, 
  3.                                         int length); 
[java]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. public static native void arraycopy(Object src,  int  srcPos,  
  2.                                         Object dest, int destPos,  
  3.                                         int length);  

src - 源数组。 
srcPos - 源数组中的起始位置。 
dest - 目标数组。 
destPos - 目标数据中的起始位置。 
length - 要复制的数组元素的数量。 
该方法是用了native关键字,调用的为C++编写的底层函数,可见其为JDK中的底层函数。 
再来看看Arrays.copyOf();该方法对于不同的数据类型都有相应的方法重载。 

[java]  view plain copy print ?
  1. //复杂数据类型 
  2. public static <T,U> T[] copyOf(U[] original,int newLength, Class<?extends T[]> newType) { 
  3.         T[] copy = ((Object)newType == (Object)Object[].class
  4.             ? (T[]) new Object[newLength] 
  5.             : (T[]) Array.newInstance(newType.getComponentType(), newLength); 
  6.         System.arraycopy(original, 0, copy,0
  7.                          Math.min(original.length, newLength)); 
  8.         return copy; 
  9.     } 
  10. public static <T> T[] copyOf(T[] original,int newLength) { 
  11.     return (T[]) copyOf(original, newLength, original.getClass()); 
[java]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. //复杂数据类型  
  2. public static <T,U> T[] copyOf(U[] original, int newLength, Class<? extends T[]> newType) {  
  3.         T[] copy = ((Object)newType == (Object)Object[].class)  
  4.             ? (T[]) new Object[newLength]  
  5.             : (T[]) Array.newInstance(newType.getComponentType(), newLength);  
  6.         System.arraycopy(original, 0, copy, 0,  
  7.                          Math.min(original.length, newLength));  
  8.         return copy;  
  9.     }  
  10. public static <T> T[] copyOf(T[] original, int newLength) {  
  11.     return (T[]) copyOf(original, newLength, original.getClass());  
  12. }  

由U类型复制为T类型?
original - 要复制的数组 
newLength - 要返回的副本的长度 
newType - 要返回的副本的类型

[java]  view plain copy print ?
  1. //基本数据类型(其他类似byte,short···) 
  2. public staticint[] copyOf(int[] original,int newLength) { 
  3.         int[] copy = new int[newLength]; 
  4.         System.arraycopy(original, 0, copy,0
  5.                          Math.min(original.length, newLength)); 
  6.         return copy; 
  7.     } 
[java]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. //基本数据类型(其他类似byte,short···)  
  2. public static int[] copyOf(int[] original, int newLength) {  
  3.         int[] copy = new int[newLength];  
  4.         System.arraycopy(original, 0, copy, 0,  
  5.                          Math.min(original.length, newLength));  
  6.         return copy;  
  7.     }  

观察其源代码发现copyOf(),在其内部创建了一个新的数组,然后调用arrayCopy()向其复制内容,返回出去。 
总结: 
1.copyOf()的实现是用的是arrayCopy(); 
2.arrayCopy()需要目标数组,对两个数组的内容进行可能不完全的合并操作。 
3.copyOf()在内部新建一个数组,调用arrayCopy()将original内容复制到copy中去,并且长度为newLength。返回copy;

4.arraycopy 方法会因为新数组大小比久数组大小小而报IndexOutOfBoundsException 

copyOf 则不会因此报错,因为copyOf 的返回值是在内部new 好的copy 数组,而该copy 数组new 的大小就等于newLength , 

    故即使在客户端指定好了新数组newArray 的大小,接收到返回值后也是指向底层new 出来的数组copy 。换句话说( 也可以因此推出其他的区别) ,在客户端代码中即使不给新数组new 对象,如:String[] newStr = null; 

    那么对于arraycopy 是会报NullPointerException 的错误的,而对于Java.util.Arrays 中的copyOf 方法则由于jdk 底层 

    已经new 出了对象而不会报该错误!不过需要特别注意的是:copyOf 方法最后也是调用System.arraycopy 的方法,不过由于前面的准备,异常情况就不会出现了。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值