Java裏對變量執行交換方法,爲什麼值沒有交換?
public class Main {
public static void main( String[] args)
{
Name tom = new Name();
Name jerry = new Name();
tom.setName("Tom");
jerry.setName("jerry");
swap(tom,jerry);
System.out.println("tom :" + tom.getName());
System.out.println("jerry :" + jerry.getName());
Name tom1 = new Name();
Name jerry1 = new Name();
tom1.setName("Tom1");
jerry1.setName("jerry1");
swap1(tom1,jerry1);
System.out.println("tom1 :" + tom1.getName());
System.out.println("jerry1 :" + jerry1.getName());
}
public static void swap(Name t,Name j)
{
Name temp = t ;
t = j;
j = temp;
}
public static void swap1(Name t,Name j)
{
String temp = t.getName();
t.setName(j.getName());
j.setName(temp);
}
}
class Name{
String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
執行結果:
從結果我們可以看到,在調用第一個交換方法後,我們的名字並沒有用改變,而調用第二個方法後,名字改變了
爲什麼沒有改變?分析如下
第一個tom和jerry在執行了setName方法之後的簡單內存形式如下
當調用swap方法後,方法頭部聲明瞭 t 和 j 的兩個Name變量,此時這兩個變量分別指向了Tom和Jerry
當swap執行結束後,四個變量的指向如下:
從內存的指向形式我們可以看到,雖然我們調用了交換方法對tom和jerry進行交換,但是在計算機內部,交換的卻是 t 和 j 的指向,而我們需要交換的兩個變量的指向吧沒有交換。以至於tom和jerry的名字沒有沒有發生交換,即只改變了形參,而爲改變實參。
爲什麼發生改變?分析如下
同樣的嗎,在tom1和jerry1命名和執行setName方法後,內存形式如下
當調用swap1變化後,方法頭部聲明瞭 t 和 j 的兩個Name變量,此時這兩個變量分別指向了Tom和Jerry
但是,在執行完swap1後的內存形式如下:
從上圖我們可以看到,變量 t 和 j 的指向並沒有發生變化,而 tom 和 jerry 的指向也沒有發生變化,但是內存裏面的值,卻發生了變化原本是Tom值變成了Jerry;而原本是Jerry的值變成了Tom,因爲在方法swap1裏面,我們的形式看上去和swap差不多,但是操作確完全不一樣
首先我們執行了 String temp = t.getName(); 即我們獲得了變量 t 的名字即Tom,然後執行t.setName(j.getName());我們將 j 的名字取出來,然後利用t.setName,這樣就對 t 的name進行了改變,而此時,t 和 tom 指向的是同一個地址,所以,當 t 發生改變時, tom就也發生了改變,同理j.setName(temp);後,jerry就也發生了改變
所以第二個交換方法,表面上是交換了兩個變量的指向,但其實,指向並沒有交換,只是將內存裏面的值改變了,而改變的值,正好是你鎖需要交換的值,而第一個只是交換了形參的指針(java沒有指針,這裏只是一種形象的說法),其實參的指針並沒有改變,所以值沒有改變