稍微看了一下原文和推文,有的是講值,有的是講方法,難以聚焦討論。
以下講方法是hashCode(),使用hashCode代表雜湊數值,是個值。
hashCode合理為hashCode()的回傳值。
我用Y或N標註,僅供參考,其中我改一個中文字會讓你的表達更清楚。
※ 引述《noapaov (單身漢)》之銘言:
: 標題: [問題] HashCode 與 記憶體位置的關聯
: 時間: Sun May 24 18:01:23 2015
:
:
: 最近看了一下書籍, 不太清楚理解是否有錯, 想請教一下各位
:
: Object 類別所提供的 hashCode() method, 主要是返回物件的記憶體位置
Y
:
: 經過運算後的整數, 所以與記憶體有密切關係
:
: 所以每個物件的HashCode()理論上應該都不一樣, 但是有些子類別繼承後會
Y
:
: 進行equals和HashCode的覆寫,例如String、Array等, 所以就有可能造成 :
hashCode()
:
: 如果兩個物件使用equals(Object) 測試結果為不相等,
:
: 則這兩個物件呼叫 hashCode 時,可以獲得不同的整數結果("可以相同,也可以不同")
^^^^
改成"但"
hashCode()
:
: 所以總結是如果繼承Object類的子類別, 沒有對equals hashCode進行改寫,
hashCode()
:
: 那麼這些物件產生的HashCode應該都不一樣, 但如果重寫就有可能造成HashCode相等, 但不一定是參考相同的記憶體位置情況
Y
:
: 不知道原理是否是這樣
N,不是原理,但就呈現來說上面你寫的都是Y。
:
: