??? 在java中,數(shù)據(jù)分為基本數(shù)據(jù)和引用型數(shù)據(jù)(也就是用new關(guān)鍵字創(chuàng)建的),java對這兩種數(shù)據(jù)的傳遞的方式是不一樣的,對于基本數(shù)據(jù)是傳值而對于引用型數(shù)據(jù)則傳遞的是數(shù)據(jù)的引用.
一個(gè)整形的數(shù)組我們用冒泡排序法進(jìn)行排序,以下是兩種示例代碼:
第一種:
第二種:
??? 經(jīng)過測試我們發(fā)現(xiàn)第一種方法正確,而第二種的結(jié)果不是我們想要的.經(jīng)過代碼的分析我們發(fā)現(xiàn)兩者的唯一區(qū)別是交換方法不一樣.
第二種的swap方法中傳入的是兩個(gè)基本數(shù)據(jù),而第一種則傳入了數(shù)組,這個(gè)引用型的數(shù)據(jù).也就是說,第二種傳入的是數(shù)據(jù)的值,把原來的值復(fù)制了一份給了swap,而當(dāng)這個(gè)訪求結(jié)束后,雖然發(fā)生了交換,但不是原來的數(shù)據(jù)發(fā)生了交換,而是其復(fù)制品.而第一種傳入了數(shù)組,由于數(shù)組是一個(gè)引用型的變量.它傳給swap方法的是數(shù)組的引用,而不是具體的值,這樣它與原來的引用都是指向heap里的同一個(gè)數(shù)據(jù),因此對這個(gè)引用的操作會(huì)直接影響到原來的數(shù)據(jù).因此第一種會(huì)出現(xiàn)我們想要的結(jié)果.
一個(gè)整形的數(shù)組我們用冒泡排序法進(jìn)行排序,以下是兩種示例代碼:
第一種:
public class BubbleSort { public static void main(String[] args) { int[] arr ={4,6,2,7,3,1,5,8}; int n = arr.length; for(int i = 0; i < n;i++) { for(int j = 0; j < n-1-i;j++) { if(arr[j]>arr[j+1]) { swap(arr,j,j+1); } } } for(int i = 0; i < arr.length; i++) System.out.print(arr[i] + " "); } public static void swap(int[] arr, int i,int j) { int term = arr[i]; arr[i] = arr[j]; arr[j] = term; } }
第二種:
public class BubbleSort { public static void main(String[] args) { int[] arr ={4,6,2,7,3,1,5,8}; int n = arr.length; for(int i = 0; i < n;i++) { for(int j = 0; j < n-1-i;j++) { if(arr[j]>arr[j+1]) { swap(arr[j],arr[j+1]); } } } for(int i = 0; i < arr.length; i++) System.out.print(arr[i] + " "); } public static void swap(int i,int j) { int term = i; i = j; j = term; } }
??? 經(jīng)過測試我們發(fā)現(xiàn)第一種方法正確,而第二種的結(jié)果不是我們想要的.經(jīng)過代碼的分析我們發(fā)現(xiàn)兩者的唯一區(qū)別是交換方法不一樣.
第二種的swap方法中傳入的是兩個(gè)基本數(shù)據(jù),而第一種則傳入了數(shù)組,這個(gè)引用型的數(shù)據(jù).也就是說,第二種傳入的是數(shù)據(jù)的值,把原來的值復(fù)制了一份給了swap,而當(dāng)這個(gè)訪求結(jié)束后,雖然發(fā)生了交換,但不是原來的數(shù)據(jù)發(fā)生了交換,而是其復(fù)制品.而第一種傳入了數(shù)組,由于數(shù)組是一個(gè)引用型的變量.它傳給swap方法的是數(shù)組的引用,而不是具體的值,這樣它與原來的引用都是指向heap里的同一個(gè)數(shù)據(jù),因此對這個(gè)引用的操作會(huì)直接影響到原來的數(shù)據(jù).因此第一種會(huì)出現(xiàn)我們想要的結(jié)果.

更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
