java編程中拷貝數(shù)組的方式及相關(guān)問題分析
JAVA數(shù)組的復(fù)制是引用傳遞,而并不是其他語言的值傳遞。
這里介紹java數(shù)組復(fù)制的4種方式極其問題:
第一種方式利用for循環(huán):
int[] a={1,2,4,6}; int length=a.length; int[] b=new int[length]; for (int i = 0; i < length; i++) { b[i]=a[i]; }
第二種方式直接賦值:
int[] array1={1,2,4,6}; int[] array2=a;
這里把a(bǔ)rray1數(shù)組的值復(fù)制給array2,如果你這樣去運(yùn)行,就會(huì)發(fā)現(xiàn)此時(shí)兩個(gè)數(shù)組的值是一樣的。這是傳遞的是引用(也就是地址),之后改變其中一個(gè)數(shù)組另一個(gè)也會(huì)跟著變化。
第三種方式:
利用Arrays自帶的copyof
int copy[] = Arrays.copyOf(a, a.length);
第四種方式:
這里再介紹一下System.arraycopy這個(gè)函數(shù),從JAVAAPI中找了一段。大家看一下。
publicstaticvoidarraycopy(Objectsrc,intsrcPos,Objectdest,intdestPos,intlength)從指定源數(shù)組中復(fù)制一個(gè)數(shù)組,復(fù)制從指定的位置開始,到目標(biāo)數(shù)組的指定位置結(jié)束。從src引用的源數(shù)組到dest引用的目標(biāo)數(shù)組,數(shù)組組件的一個(gè)子序列被復(fù)制下來。被復(fù)制的組件的編號(hào)等于length參數(shù)。源數(shù)組中位置在srcPos到srcPos+length-1之間的組件被分別復(fù)制到目標(biāo)數(shù)組中的destPos到destPos+length-1位置。
如果參數(shù)src和dest引用相同的數(shù)組對(duì)象,則復(fù)制的執(zhí)行過程就好像首先將srcPos到srcPos+length-1位置
的組件復(fù)制到一個(gè)帶有l(wèi)ength組件的臨時(shí)數(shù)組,然后再將此臨時(shí)數(shù)組的內(nèi)容復(fù)制到目標(biāo)數(shù)組的destPos到
destPos+length-1位置一樣。
If如果dest為null,則拋出NullPointerException異常。
如果src為null,則拋出NullPointerException異常,并且不會(huì)修改目標(biāo)數(shù)組。
否則,只要下列任何情況為真,則拋出ArrayStoreException異常并且不會(huì)修改目標(biāo)數(shù)組:
src參數(shù)指的是非數(shù)組對(duì)象。
dest參數(shù)指的是非數(shù)組對(duì)象。
src參數(shù)和dest參數(shù)指的是那些其組件類型為不同基本類型的數(shù)組。
src參數(shù)指的是具有基本組件類型的數(shù)組且dest參數(shù)指的是具有引用組件類型的數(shù)組。
src參數(shù)指的是具有引用組件類型的數(shù)組且dest參數(shù)指的是具有基本組件類型的數(shù)組。
否則,只要下列任何情況為真,則拋出IndexOutOfBoundsException異常,并且不會(huì)修改目標(biāo)數(shù)組:
srcPos參數(shù)為負(fù)。
destPos參數(shù)為負(fù)。
length參數(shù)為負(fù)。
srcPos+length大于src.length,即源數(shù)組的長(zhǎng)度。
destPos+length大于dest.length,即目標(biāo)數(shù)組的長(zhǎng)度。
否則,如果源數(shù)組中srcPos到srcPos+length-1位置上的實(shí)際組件通過分配轉(zhuǎn)換并不能轉(zhuǎn)換成目標(biāo)數(shù)組的組
件類型,則拋出ArrayStoreException異常。在這種情況下,將k設(shè)置為比長(zhǎng)度小的最小非負(fù)整數(shù),這樣就
無法將src[srcPos+k]轉(zhuǎn)換為目標(biāo)數(shù)組的組件類型;當(dāng)拋出異常時(shí),從srcPos到srcPos+k-1位置上的源數(shù)組
組件已經(jīng)被復(fù)制到目標(biāo)數(shù)組中的destPos到destPos+k-1位置,而目標(biāo)數(shù)組中的其他位置不會(huì)被修改。(因
為已經(jīng)詳細(xì)說明過的那些限制,只能將此段落有效地應(yīng)用于兩個(gè)數(shù)組都有引用類型的組件類型的情況。)
參數(shù):src-源數(shù)組。
srcPos-源數(shù)組中的起始位置。
dest-目標(biāo)數(shù)組。
destPos-
目標(biāo)數(shù)據(jù)中的起始位置。
length-
要復(fù)制的數(shù)組元素的數(shù)量。
拋出:IndexOutOfBoundsException-
如果復(fù)制會(huì)導(dǎo)致對(duì)數(shù)組范圍以外的數(shù)據(jù)的訪問。
ArrayStoreException-如果因?yàn)轭愋筒黄ヅ涠沟脽o法將src數(shù)組中的元素存儲(chǔ)到dest數(shù)組中。
NullPointerException-如果src或dest為null。
二維數(shù)組
不想匆匆了事,那就再介紹一下二維數(shù)組的聲明、初始化和引用吧。
二維數(shù)組的聲明、初始化和引用與一維數(shù)組相似:
int intArray[ ][ ] = { {1,2}, {2,3}, {4,5} }; int a[ ][ ] = new int[2][3]; a[0][0] = 12; a[0][1] = 34; // ...... a[1][2] = 93;
Java語言中,由于把二維數(shù)組看作是數(shù)組的數(shù)組,數(shù)組空間不是連續(xù)分配的,所以不要求二維數(shù)組每一維的大小相同。例如:
int intArray[ ][ ] = { {1,2}, {2,3}, {3,4,5} }; int a[ ][ ] = new int[2][ ]; a[0] = new int[3]; a[1] = new int[5];
【示例】通過二維數(shù)組計(jì)算兩個(gè)矩陣的乘積。
public class Demo { public static void main(String[] args){ // 第一個(gè)矩陣(動(dòng)態(tài)初始化一個(gè)二維數(shù)組) int a[][] = new int[2][3]; // 第二個(gè)矩陣(靜態(tài)初始化一個(gè)二維數(shù)組) int b[][] = { {1,5,2,8}, {5,9,10,-3}, {2,7,-5,-18} }; // 結(jié)果矩陣 int c[][] = new int[2][4]; // 初始化第一個(gè)矩陣 for (int i=0; i<2; i++) for (int j=0; j<3 ;j++) a[i][j] = (i+1) * (j+2); // 計(jì)算矩陣乘積 for (int i=0; i<2; i++){ for (int j=0; j<4; j++){ c[i][j]=0; for (int k=0; k<3; k++) c[i][j] += a[i][k] * b[k][j]; } } // 輸出結(jié)算結(jié)果 for (int i=0; i<2; i++){ for (int j=0; j<4; j++) System.out.printf("%-5d", c[i][j]); System.out.printlnwww.ymzxrj.com(); } } }
運(yùn)行結(jié)果:
25 65 14 -65
50 130 28 -130
總結(jié)
以上就是本文關(guān)于java編程中拷貝數(shù)組的方式及相關(guān)問題分析的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:
java數(shù)組復(fù)制的四種方法效率對(duì)比
Java中的數(shù)組復(fù)制(clone與arraycopy)代碼詳解
淺談java中String的兩種賦值方式的區(qū)別
如有不足之處,歡迎留言指出,期待您的寶貴意見!
上一篇:Java編程BigDecimal用法實(shí)例分享
欄 目:Java編程
下一篇:Java編程將漢字轉(zhuǎn)Unicode碼代碼示例
本文標(biāo)題:java編程中拷貝數(shù)組的方式及相關(guān)問題分析
本文地址:http://mengdiqiu.com.cn/a1/Javabiancheng/8425.html
您可能感興趣的文章
- 01-10Java咖啡館(1)——嘆咖啡
- 01-10Java Socket編程(三) 服務(wù)器Sockets
- 01-10Java進(jìn)階:Struts多模塊的技巧
- 01-10Java Socket編程(一) Socket傳輸模式
- 01-10Java Socket編程(二) Java面向連接的類
- 01-10Java運(yùn)行時(shí)多態(tài)性的實(shí)現(xiàn)
- 01-10Java經(jīng)驗(yàn)點(diǎn)滴:處理沒有被捕獲的異常
- 01-10Java Socket編程(四) 重復(fù)和并發(fā)服務(wù)器
- 01-10Java中的浮點(diǎn)數(shù)分析
- 01-10面向?qū)ο缶幊?Java中的抽象數(shù)據(jù)類型


閱讀排行
- 1C語言 while語句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10Java咖啡館(1)——嘆咖啡
- 01-10JVM的垃圾回收機(jī)制詳解和調(diào)優(yōu)
- 01-10Java Socket編程(三) 服務(wù)器Sockets
- 01-10Java進(jìn)階:Struts多模塊的技巧
- 01-10J2SE 1.5版本的新特性一覽
- 01-10Java Socket編程(一) Socket傳輸模式
- 01-10Java運(yùn)行時(shí)多態(tài)性的實(shí)現(xiàn)
- 01-10Java Socket編程(二) Java面向連接的類
- 01-10Java Socket編程(四) 重復(fù)和并發(fā)服務(wù)
- 01-10Java經(jīng)驗(yàn)點(diǎn)滴:處理沒有被捕獲的異常
隨機(jī)閱讀
- 01-10delphi制作wav文件的方法
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-11ajax實(shí)現(xiàn)頁面的局部加載