從內存上看swap

問題: 如果Java是用引用來傳遞的話,爲什麼交換函數(swap)不起作用呢?

public void tricky(Point arg1, Point arg2)
{
    arg1.x = 100;
    arg1.y = 100;
    Point temp = arg1;
    arg1 = arg2;
    arg2 = temp;
}

public static void main(String [] args)
{
    Point pnt1 = new Point(0,0);
    Point pnt2 = new Point(0,0);
    System.out.println("X: " + pnt1.x + " Y: " +pnt1.y);
    System.out.println("X: " + pnt2.x + " Y: " +pnt2.y);
    System.out.println(" ");
    tricky(pnt1,pnt2);
    System.out.println("X: " + pnt1.x + " Y:" + pnt1.y);
    System.out.println("X: " + pnt2.x + " Y: " +pnt2.y);
}

執行這個函數,將得到以下輸出:
———————————————————-
X: 0 Y: 0
X: 0 Y: 0


X: 100 Y: 100
X: 0 Y: 0

原因:
(1)在main()函數當中,pnt1和pnt2僅僅是對象的引用。
(2)當向tricky()函數傳遞pnt1和pnt2參數時,Java僅僅向傳遞任何其他參數一樣,通過傳值來傳遞引用。傳向函數的引用實際上是原始引用的副本。

———————————————————-

圖一: 當被傳遞給函數之後,一個對象至少存在兩個引用
這裏寫圖片描述

圖二: 只有傳入函數的引用交換了,原始引用則沒有
這裏寫圖片描述
———————————————————-

總結:在內存機制上分析引用傳遞問題思路更清晰。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章