小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

Arrays.copyof(···)與System.arraycopy(···)區(qū)別

 瑤疏影 2017-03-17
 http://blog.csdn.net/shijinupc/article/details/7827507 
首先觀察先System.arraycopy(Object src, int srcPos, Object dest, int destPos, int length)的聲明:
  1. public static native void arraycopy(Object src,  int  srcPos,  
  2.                                         Object dest, int destPos,  
  3.                                         int length);  

src - 源數(shù)組。
srcPos - 源數(shù)組中的起始位置。
dest - 目標數(shù)組。
destPos - 目標數(shù)據(jù)中的起始位置。
length - 要復制的數(shù)組元素的數(shù)量。
該方法是用了native關鍵字,調用的為C++編寫的底層函數(shù),可見其為JDK中的底層函數(shù)。
再來看看Arrays.copyOf();該方法對于不同的數(shù)據(jù)類型都有相應的方法重載。

  1. //復雜數(shù)據(jù)類型  
  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 - 要復制的數(shù)組
newLength - 要返回的副本的長度
newType - 要返回的副本的類型

  1. //基本數(shù)據(jù)類型(其他類似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.     }  
觀察其源代碼發(fā)現(xiàn)copyOf(),在其內(nèi)部創(chuàng)建了一個新的數(shù)組,然后調用arrayCopy()向其復制內(nèi)容,返回出去。
總結:
1.copyOf()的實現(xiàn)是用的是arrayCopy();
2.arrayCopy()需要目標數(shù)組,對兩個數(shù)組的內(nèi)容進行可能不完全的合并操作。
3.copyOf()在內(nèi)部新建一個數(shù)組,調用arrayCopy()將original內(nèi)容復制到copy中去,并且長度為newLength。返回copy; 

    本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內(nèi)容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多