自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

有關(guān)Java數(shù)組間賦值的問(wèn)題

開發(fā) 后端
本文由作者在實(shí)際調(diào)試中出現(xiàn)問(wèn)題解決問(wèn)題,從而發(fā)現(xiàn)的Java數(shù)組間賦值的一些做法、技巧和需要注意的方面。

今天寫個(gè)JAVA程序,老是出現(xiàn)錯(cuò)誤,于是單步調(diào)試了很久,真的很久,NND ,幾百行的程序調(diào)試了老半天了都,結(jié)果終于被我發(fā)現(xiàn)問(wèn)題的說(shuō)在了,不過(guò)費(fèi)了這么多事,原來(lái)是一個(gè)JAVA的一個(gè)細(xì)節(jié)的東西在搞鬼,我是初學(xué)JAVA,對(duì)JAVA的了解也沒(méi)有那么深入,所以它的特性也么有掌握好,不過(guò)今天被這些細(xì)節(jié)的東西整慘了。
大家都知道,在C 和C++中,數(shù)組是不能直接被賦值的,假設(shè)有兩個(gè)數(shù)組 a[10],b[10],在C和C++中是不能以 a=b的方式把b中的內(nèi)容賦值給相應(yīng)的數(shù)組a的,因?yàn)閍和b的值其實(shí)就是該數(shù)組的頭指針指向的地址,當(dāng)然如果很了解數(shù)組的實(shí)現(xiàn)原理的話,這就很好理解了,在《數(shù)據(jù)結(jié)果》的可能中有涉及到,總之知道數(shù)據(jù)的數(shù)組名就是數(shù)組的頭指針指向的***元素的地址,如果能這樣理解的話,那么用大腿想一下就知道a=b是不能實(shí)現(xiàn)數(shù)組的賦值的,一般在C和C++中我們采用了一個(gè)循環(huán)來(lái)單個(gè)賦值,類似這樣的:

  1. for(int i=0;i<10;i++)   
  2. a[i]=b[i]; 

方式來(lái)實(shí)現(xiàn),學(xué)了這么久的C和C++,用的多了,也不覺(jué)得費(fèi)事。但是在JAVA中卻不想C和C++一樣,JAVA 很聰明,它可以使用 a=b 的方式來(lái)將b 賦值給a,這里的賦值要注意了,在JAVA中使用 a=b 的時(shí)候,在 a 中以數(shù)組的方式來(lái)輸出內(nèi)容的時(shí)候,跟b 的內(nèi)容一模一樣,說(shuō)明這樣的方式可行,我的程序里面就是這樣用的,結(jié)果整出了BUG來(lái)了。一開始發(fā)現(xiàn)不管是用 a=b 還是用 a=a.clone(); 結(jié)果都是一樣,有些不解,不過(guò)現(xiàn)在我完全清楚了。為了說(shuō)明這個(gè)問(wèn)題,以一段程序演示一下:

  1. private int[] subResources(int[] aa, int[] bb)  
  2. {  
  3.    // 做減法  
  4.    int []a=aa;  
  5.    int []b=bb;  
  6.    for (int i = 0; i < a.length; i++)  
  7.     a[i] = a[i] - b[i];  
  8.    return a;  

這是用來(lái)實(shí)現(xiàn)兩個(gè)數(shù)組想減的函數(shù),在調(diào)用的程序中這樣使用

  1. int []allo=pcb0.getAllocation().clone(); //方式1  
  2.  
  3. //int []allo=pcb0.getAllocation()//方式2  
  4.    int[] allocation = this.addResources(allo, request); 

上面兩種方式的參數(shù)傳入帶來(lái)的不同結(jié)果是,當(dāng)你在函數(shù)addResources 修改了傳入?yún)?shù)的值的時(shí)候,方式1不能改原來(lái)的數(shù)據(jù),方式2能改變?cè)瓉?lái)的數(shù)據(jù)。方式1它賦值的時(shí)候是先創(chuàng)建一個(gè)數(shù)組的副本,再把副本來(lái)給目標(biāo)數(shù)組賦值,這樣副本數(shù)組的地址和原來(lái)數(shù)組的地址當(dāng)然不是同一個(gè)了,這樣不管你怎么改,方式1它都不會(huì)改變?cè)瓉?lái)的數(shù)據(jù),方式2則不一樣,方式2它直接將數(shù)據(jù)的地址賦值給目標(biāo)數(shù)據(jù),這樣兩個(gè)數(shù)組不同的數(shù)組名,其實(shí)指的都是同一個(gè)地址,這樣當(dāng)然可以改變?cè)瓉?lái)的值了。

這樣分析,它有點(diǎn)像C++中的函數(shù)傳參中的 指針和引用傳值一樣,由于java中都摒棄了指針,所以所有的指向關(guān)系都使用了引用類型,用C++用久了就容易犯這樣的錯(cuò)誤。不像C++中這樣傳值 addResources (int *a,int *b) 或者 addResources (int a[],int b[]) 。這會(huì)吃虧了,看來(lái)這輩子在這個(gè)地方就這次了,學(xué)東西還得專注一點(diǎn)啊,現(xiàn)在明白了為什么招聘會(huì)上的基礎(chǔ)題看起來(lái)簡(jiǎn)單,卻不是每個(gè)人都能答好的。

責(zé)任編輯:仲衡 來(lái)源: 網(wǎng)易日志
相關(guān)推薦

2009-08-11 14:55:44

C#枚舉

2010-02-07 11:13:04

Android設(shè)備間

2010-01-08 09:30:03

Java數(shù)組JVM

2020-02-04 14:07:47

Java技術(shù)開發(fā)

2010-07-08 12:49:12

SIP會(huì)話發(fā)起協(xié)議

2010-03-09 16:38:22

Linux grub啟

2010-05-05 17:53:56

web負(fù)載均衡

2010-08-25 17:23:12

DHCP移植

2010-09-15 09:20:40

2009-07-02 17:39:46

Java未來(lái)

2009-12-17 11:47:44

FedoraJSP

2021-06-06 17:32:09

人臉識(shí)別AI人工智能

2021-07-26 05:20:47

JavaScript解構(gòu)賦值數(shù)組解構(gòu)

2024-07-17 11:35:31

JavaScript解構(gòu)賦值

2024-09-10 15:34:18

JavaScript解構(gòu)賦值

2024-06-18 10:28:46

2009-08-13 13:03:52

C#結(jié)構(gòu)體數(shù)組

2009-08-13 13:17:10

C#結(jié)構(gòu)體數(shù)組

2024-01-29 00:30:00

C語(yǔ)言代碼數(shù)組

2010-06-09 16:57:14

路由選擇協(xié)議
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)