hashcode:對象的初始地址的整數表示 算法
Java中的對象是JVM在管理,JVM會在她認爲合適的時候對對象進行移動,好比,在某些須要整理內存碎片的GC算法下發生的GC。此時,對象的地址會變更,但hashcode不會改變。 性能
1.hashCode是爲了提升在散列結構存儲中查找的效率,在線性表中沒有做用。code
4.若兩個對象equals返回false,則hashCode不必定返回不一樣的int數,但爲不相等的對象生成不一樣hashCode值能夠提升哈希表的性能。對象
5.若兩個對象hashCode返回相同int數,則equals不必定返回true。內存
6.若兩個對象hashCode返回不一樣int數,則equals必定返回false。hash
7.同一對象在執行期間若已經存儲在集合中,則不能修改影響hashCode值的相關信息,不然會致使內存泄露問題。效率
8.通常來講涉及到對象之間的比較大小就須要重寫equals方法。方法