課程
/后端開發
/Java
/Java入門第二季 升級版
可以直接用哈希碼來判斷嗎 ?我感覺用哈希碼更容易些了。。。
2018-06-18
源自:Java入門第二季 升級版 9-9
正在回答
hashCode 是一個“散列值碼”。散列值,并不能表現其唯一性,但是有離散性,其意義在于類似于進行hashMap等操作時,加快對象比較的速度,進而加快對象搜索的速度。hashCode 和 equals的關系:兩個對象 equals的時候,hashCode必須相等,但hashCode相等,對象不一定equals。
最后明白兩點就行了:1.hashCode()方法存在的主要目的就是提高效率。2.在集合中判斷兩個對象相等的條件,其實無論是往集合中存數據,還是從集合中取數據,包括如果控制唯一性等,都是用這個條件判斷的,條件如下:??? 首先判斷兩個對象的hashCode是否相等,如果不相等,就認為這兩個對象不相等,就完成了。如果相等,才會判斷兩個對象的equals()是否相等,如果不相等,就認為這兩個對象不相等,如果相等,那就認為這兩個對象相等。
最后總結一句話就是,hashCode()方法存在的主要目的就是提高效率,但是如果你想把對象放到散列存儲結構的集合中時,是必須要重寫的。
舉報
課程升級!以終為始告別枯燥,在開發和重構中體會Java面向對象編程的奧妙
3 回答判斷對象是否相同
2 回答判斷兩個對象類型是否相同?用 obj instanceof Dog 可以么?
3 回答判斷父類對象類型
4 回答重寫equals的代碼中已經用getclass判斷了兩個對象的類型是否一樣為什么還要再強制轉換一次?
1 回答如何判斷是否需要實例化?
Copyright ? 2025 imooc.com All Rights Reserved | 京ICP備12003892號-11 京公網安備11010802030151號
購課補貼聯系客服咨詢優惠詳情
慕課網APP您的移動學習伙伴
掃描二維碼關注慕課網微信公眾號
2018-06-19
hashCode 是一個“散列值碼”。
散列值,并不能表現其唯一性,但是有離散性,其意義在于類似于進行hashMap等操作時,加快對象比較的速度,進而加快對象搜索的速度。
hashCode 和 equals的關系:
兩個對象 equals的時候,hashCode必須相等,但hashCode相等,對象不一定equals。
最后明白兩點就行了:
1.hashCode()方法存在的主要目的就是提高效率。
2.在集合中判斷兩個對象相等的條件,其實無論是往集合中存數據,還是從集合中取數據,包括如果控制唯一性等,都是用這個條件判斷的,條件如下:
??? 首先判斷兩個對象的hashCode是否相等,如果不相等,就認為這兩個對象不相等,就完成了。如果相等,才會判斷兩個對象的equals()是否相等,如果不相等,就認為這兩個對象不相等,如果相等,那就認為這兩個對象相等。
最后總結一句話就是,hashCode()方法存在的主要目的就是提高效率,但是如果你想把對象放到散列存儲結構的集合中時,是必須要重寫的。