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方法。方法

相关文章
相关标签/搜索