真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

java編程中拷貝數(shù)組的方式及相關(guān)問題分析

JAVA數(shù)組的復(fù)制是引用傳遞,而并不是其他語言的值傳遞。

創(chuàng)新互聯(lián)建站是一家專業(yè)提供桑珠孜企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計、成都網(wǎng)站設(shè)計、H5高端網(wǎng)站建設(shè)、小程序制作等業(yè)務(wù)。10年已為桑珠孜眾多企業(yè)、政府機構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進行中。

這里介紹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;

這里把array1數(shù)組的值復(fù)制給array2,如果你這樣去運行,就會發(fā)現(xiàn)此時兩個數(shù)組的值是一樣的。這是傳遞的是引用(也就是地址),之后改變其中一個數(shù)組另一個也會跟著變化。

第三種方式:

利用Arrays自帶的copyof

int copy[] = Arrays.copyOf(a, a.length);

第四種方式:

這里再介紹一下System.arraycopy這個函數(shù),從JAVAAPI中找了一段。大家看一下。

publicstaticvoidarraycopy(Objectsrc,intsrcPos,Objectdest,intdestPos,intlength)從指定源數(shù)組中復(fù)制一個數(shù)組,復(fù)制從指定的位置開始,到目標數(shù)組的指定位置結(jié)束。從src引用的源數(shù)組到dest引用的目標數(shù)組,數(shù)組組件的一個子序列被復(fù)制下來。被復(fù)制的組件的編號等于length參數(shù)。源數(shù)組中位置在srcPos到srcPos+length-1之間的組件被分別復(fù)制到目標數(shù)組中的destPos到destPos+length-1位置。

如果參數(shù)src和dest引用相同的數(shù)組對象,則復(fù)制的執(zhí)行過程就好像首先將srcPos到srcPos+length-1位置

的組件復(fù)制到一個帶有l(wèi)ength組件的臨時數(shù)組,然后再將此臨時數(shù)組的內(nèi)容復(fù)制到目標數(shù)組的destPos到

destPos+length-1位置一樣。

If如果dest為null,則拋出NullPointerException異常。

如果src為null,則拋出NullPointerException異常,并且不會修改目標數(shù)組。

否則,只要下列任何情況為真,則拋出ArrayStoreException異常并且不會修改目標數(shù)組:

src參數(shù)指的是非數(shù)組對象。

dest參數(shù)指的是非數(shù)組對象。

src參數(shù)和dest參數(shù)指的是那些其組件類型為不同基本類型的數(shù)組。

src參數(shù)指的是具有基本組件類型的數(shù)組且dest參數(shù)指的是具有引用組件類型的數(shù)組。

src參數(shù)指的是具有引用組件類型的數(shù)組且dest參數(shù)指的是具有基本組件類型的數(shù)組。

否則,只要下列任何情況為真,則拋出IndexOutOfBoundsException異常,并且不會修改目標數(shù)組:

srcPos參數(shù)為負。

destPos參數(shù)為負。

length參數(shù)為負。

srcPos+length大于src.length,即源數(shù)組的長度。

destPos+length大于dest.length,即目標數(shù)組的長度。

否則,如果源數(shù)組中srcPos到srcPos+length-1位置上的實際組件通過分配轉(zhuǎn)換并不能轉(zhuǎn)換成目標數(shù)組的組

件類型,則拋出ArrayStoreException異常。在這種情況下,將k設(shè)置為比長度小的最小非負整數(shù),這樣就

無法將src[srcPos+k]轉(zhuǎn)換為目標數(shù)組的組件類型;當(dāng)拋出異常時,從srcPos到srcPos+k-1位置上的源數(shù)組

組件已經(jīng)被復(fù)制到目標數(shù)組中的destPos到destPos+k-1位置,而目標數(shù)組中的其他位置不會被修改。(因

為已經(jīng)詳細說明過的那些限制,只能將此段落有效地應(yīng)用于兩個數(shù)組都有引用類型的組件類型的情況。)

參數(shù):src-源數(shù)組。

srcPos-源數(shù)組中的起始位置。

dest-目標數(shù)組。

destPos-

目標數(shù)據(jù)中的起始位置。

length-

要復(fù)制的數(shù)組元素的數(shù)量。

拋出:IndexOutOfBoundsException-

如果復(fù)制會導(dǎo)致對數(shù)組范圍以外的數(shù)據(jù)的訪問。

ArrayStoreException-如果因為類型不匹配而使得無法將src數(shù)組中的元素存儲到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ù)組計算兩個矩陣的乘積。

public class Demo {
	public static void main(String[] args){
		// 第一個矩陣(動態(tài)初始化一個二維數(shù)組)
		int a[][] = new int[2][3];
		// 第二個矩陣(靜態(tài)初始化一個二維數(shù)組)
		int b[][] = { {1,5,2,8}, {5,9,10,-3}, {2,7,-5,-18} };
		// 結(jié)果矩陣
		int c[][] = new int[2][4];
		// 初始化第一個矩陣
		for (int i=0; i<2; i++)
		for (int j=0; j<3 ;j++)
		a[i][j] = (i+1) * (j+2);
		// 計算矩陣乘積
		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();
		}
	}
}

運行結(jié)果:

25 65 14 -65
50 130 28 -130

總結(jié)

以上就是本文關(guān)于java編程中拷貝數(shù)組的方式及相關(guān)問題分析的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:

java數(shù)組復(fù)制的四種方法效率對比

Java中的數(shù)組復(fù)制(clone與arraycopy)代碼詳解

淺談java中String的兩種賦值方式的區(qū)別

如有不足之處,歡迎留言指出,期待您的寶貴意見!


新聞名稱:java編程中拷貝數(shù)組的方式及相關(guān)問題分析
URL分享:http://weahome.cn/article/jcdjjj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部