5.1.7 數(shù)組元素的復制
從前面的講解中我們了解到,如果我們用一個已經(jīng)初始化后的數(shù)組為另一個剛剛聲明的數(shù)組做初始化,那么這兩個數(shù)組實際上會指向同一個數(shù)組,對其中一個數(shù)組的操作會影響到另一個數(shù)組的值,在實際應該用中,經(jīng)常會遇到只是想將數(shù)組的值賦值到另一個數(shù)組,被賦值的數(shù)組的修改對原數(shù)組不產(chǎn)生影響的情況。這時候我們就不能采用“int[]a=b”(b是一個已初始化的數(shù)組)了,可以通過如下的for循環(huán)完成:
for(int i=0;i b[i]=a[i];
}
在java中提供了一個現(xiàn)有的方法實現(xiàn)數(shù)組元素的復制,它就是“System.arraycopy”方法,該方法的原型為:
public static void arraycopy(Object src,int srcPos,
Object dest,int destPos, int length)
各參數(shù)的意義:
src - 源數(shù)組。
srcPos - 源數(shù)組中的起始位置。
dest - 目標數(shù)組。
destPos - 目標數(shù)據(jù)中的起始位置。
length - 要復制的數(shù)組元素的個數(shù)。
方法的具體含義:
從指定源數(shù)組中復制一個數(shù)組,復制從指定的位置開始,到目標數(shù)組的指定位置結束。從 src 引用的源數(shù)組到 dest 引用的目標數(shù)組,數(shù)組的一個子序列被復制下來。源數(shù)組中位置在 srcPos 到 srcPos+length-1 之間的數(shù)組 元素被分別復制到目標數(shù)組中的 destPos 到 destPos+length-1 位置。
如果參數(shù) src 和 dest 引用相同的數(shù)組對象,則復制的執(zhí)行過程就好像首先將 srcPos 到 srcPos+length-1 位置的元素復制到一個帶有 length 個元素的臨時數(shù)組,然后再將此臨時數(shù)組的內容復制到目標數(shù)組的 destPos 到 destPos+length-1 位置一樣。 不會造成讀和寫的沖突。
在使用該方法時,需注意,如果參數(shù)的數(shù)據(jù)錯誤有可能會引起以下幾種異常(有關異常的內容請參見第10章)。
NullPointerException異常:這個異常的產(chǎn)生可能是因為源數(shù)組src或目標數(shù)組dest并沒有引用到一個數(shù)組的實例,即數(shù)組沒有初始化,這樣數(shù)組的引用值為null,就會產(chǎn)生這個異常。如果這個是因為為null,則目標數(shù)組并不會去做任何的修。
ArrayStoreException異常:這個異常的產(chǎn)生原因可能是來源或目標數(shù)組根本就不是數(shù)組,或者是來源目標數(shù)組不是基本類型的數(shù)組。Arraycopy只適用基本數(shù)據(jù)類型的數(shù)組。
IndexOutOfBoundsException異常:這個異常的產(chǎn)生原因是索引值指定錯誤。包括srcPos、destPos和length值為負數(shù),或者srcPos+length 大于 src.length,destPos+length 大于 dest.length。這些情況中的任何一種都會引發(fā)IndexOutOfBoundsException異常。
例[5-8]
public class Test5_8 {
public static void main(String[] args) {
int[] a={12,43,54,56,78};
int[] b=new int[8];
System.arraycopy(a, 1, b, 2, 4);
for(int i=0;i System.out.print(b[i]+"\t");
}
}
}
由上面關于arraycopy的解釋我們知道System.arraycopy(a, 1, b, 2, 4),表示將數(shù)組a中下標為1開始的元素復制給數(shù)組b中下標為2開始的4個元素。
運行結果為:
0 0 43 54 56 78 0 0
可能讀者會有這樣的疑問,既然我們自己通過for語句也可以控制兩個數(shù)組的復制,那么為什么還需要使用arraycopy方法呢?
原因有兩個:系統(tǒng)給定的方法時經(jīng)過嚴格測試的方法,一般不存在錯誤,且考慮了各種異常情況,比自己寫的考慮全面;再有,arraycopy在內部實現(xiàn)上使用的是JNI的方法(即調用本地的其他語言所寫的程序的方法),運行速度上會比我們用java寫的程序要快。

