標籤:java hashcode equals 網易 傳引用
<pre name="code" class="java">public class JavaTestDemo1 {public static void main(String[] args) {Integer v1 = new Integer(1);Integer v2 = v1;doSomething(v2);System.out.println(v2);System.out.println(v1 == v2);System.out.println(v1.equals(v2));}public static void doSomething(Integer i) {i = new Integer(10);}}
上面代碼的執行結果是:
1 true true
分析:
Java對象在參數中是傳引用的方式傳遞的,初始化v1和v2指向同樣的地址空間。
那下面就提出2個疑問:
1.Java函數參數中,對象是傳引用的方式,為什麼v2的值仍是1而不是10
2.按理來說,在doSomething中v2應該指向Integer(10)所在的記憶體位址,那為什麼v1.equals(v2)的值會是true?
讓我們先瞭解一下Java基類Object中hashCode和equals的作用:
hashCode()方法被用來擷取給定對象的唯一整數。這個整數被用來確定對象被儲存在HashTable類似的結構中的位置。預設的,Object類的hashCode()方法返回這個Object Storage Service的記憶體位址的編號。
也就是說,如果兩個對象指向不同的地址,那麼equals的值肯定返回false。
先解答第一個問題:
為什麼v2的值是1而不是10:因為在doSomething中做的事如下:建立了一個i對象,指向v2,然後讓這個i對象重新指向new Integer(10)的地址,使之完全脫離了與v1,v2的關係。所以v1, v2的值仍是1(注,Integer,Double等本身的value也是用final聲明的,不可改變的)。
第二個問題:
v1,v2始終指向同一個對象,那用equals肯定是返回true咯。 況且我們看看Integer的原源就可以發現,Integer已經重寫了Obejct中的equals函數,只要數值相同,即使指定不同地址的Integer對象進行equals比較返回結果也是true
public boolean equals(Object obj) { if (obj instanceof Integer) { return value == ((Integer)obj).intValue(); } return false;}
著作權聲明:本文為博主原創文章,未經博主允許不得轉載。
關於Java傳值&傳引用的一道題