偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

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

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

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

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

方式來實現(xiàn),學了這么久的C和C++,用的多了,也不覺得費事。但是在JAVA中卻不想C和C++一樣,JAVA 很聰明,它可以使用 a=b 的方式來將b 賦值給a,這里的賦值要注意了,在JAVA中使用 a=b 的時候,在 a 中以數(shù)組的方式來輸出內(nèi)容的時候,跟b 的內(nèi)容一模一樣,說明這樣的方式可行,我的程序里面就是這樣用的,結(jié)果整出了BUG來了。一開始發(fā)現(xiàn)不管是用 a=b 還是用 a=a.clone(); 結(jié)果都是一樣,有些不解,不過現(xià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;  

這是用來實現(xiàn)兩個數(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ù)傳入帶來的不同結(jié)果是,當你在函數(shù)addResources 修改了傳入?yún)?shù)的值的時候,方式1不能改原來的數(shù)據(jù),方式2能改變原來的數(shù)據(jù)。方式1它賦值的時候是先創(chuàng)建一個數(shù)組的副本,再把副本來給目標數(shù)組賦值,這樣副本數(shù)組的地址和原來數(shù)組的地址當然不是同一個了,這樣不管你怎么改,方式1它都不會改變原來的數(shù)據(jù),方式2則不一樣,方式2它直接將數(shù)據(jù)的地址賦值給目標數(shù)據(jù),這樣兩個數(shù)組不同的數(shù)組名,其實指的都是同一個地址,這樣當然可以改變原來的值了。

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

責任編輯:仲衡 來源: 網(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-03-09 16:38:22

Linux grub啟

2010-07-08 12:49:12

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

2010-05-05 17:53:56

web負載均衡

2010-08-25 17:23:12

DHCP移植

2010-09-15 09:20:40

2009-07-02 17:39:46

Java未來

2009-12-17 11:47:44

FedoraJSP

2021-06-06 17:32:09

人臉識別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

2013-04-19 09:16:56

2010-06-09 16:57:14

路由選擇協(xié)議

2019-09-25 14:48:03

區(qū)塊鏈以太坊比特幣

2012-06-29 13:31:56

ServletJSPJava
點贊
收藏

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