hashcode和equals區別

hashcode:對象的初始地址的整數表示     算法

Java中的對象是JVM在管理,JVM會在她認爲合適的時候對對象進行移動,好比,在某些須要整理內存碎片的GC算法下發生的GC。此時,對象的地址會變更,但hashcode不會改變。   性能

  1.hashCode是爲了提升在散列結構存儲中查找的效率,在線性表中沒有做用。code

       2.通常一個類的對象若是會存儲在HashTable,HashSet,HashMap等散列存儲結構中,那麼重寫equals後最好也重寫hashCode,不然會致使存儲數據的不惟一性(存儲了兩個equals相等的數據)。而若是肯定不會存儲在這些散列結構中,則能夠不重寫hashCode。
       3.若兩個對象equals返回true,則hashCode有必要也返回相同的int數。

       4.若兩個對象equals返回false,則hashCode不必定返回不一樣的int數,但爲不相等的對象生成不一樣hashCode值能夠提升哈希表的性能。對象

       5.若兩個對象hashCode返回相同int數,則equals不必定返回true。內存

       6.若兩個對象hashCode返回不一樣int數,則equals必定返回false。hash

       7.同一對象在執行期間若已經存儲在集合中,則不能修改影響hashCode值的相關信息,不然會致使內存泄露問題。效率

  8.通常來講涉及到對象之間的比較大小就須要重寫equals方法。方法

相關文章
相關標籤/搜索