目录
==
- 它的作用是判断两个对象的地址是不是相等
- 基本数据类型比较的是值,引用数据类型比较的是内存地址
equals
- 类没有覆盖 equals() 方法。则通过 equals() 比较该类的两个对象时,等价于通过“==”比较这两个对象
- 类覆盖了 equals() 方法。一般,我们都覆盖 equals() 方法来比较两个对象的内容是否相等;若它们的内容相等,则返回 true (即,认为这两个对象相等)
关于String的equals
- String 中的 equals 方法是被重写过的,因为 object 的 equals 方法是只比较的对象的内存地址,而 String 的 equals 方法是先比较内存地址,如果地址不同,则比较具体的值
hashCode()
- hashCode() 的作用是获取哈希码,也称为
散列码
;它实际上是返回一个int 整数
- 这个哈希码的作用是确定该对象在
哈希表中的索引位置
- hashCode() 定义在 JDK 的 Object.java 中,这就意味着 Java 中的
任何类都包含
有 hashCode() 函数 - 散列表存储的是键值对(key-value),它的特点是:能根据“键”快速的检索出对应的“值”,这其中就利用到了散列码!(
可以快速找到所需要的对象
)
为什么要有 hashCode
- 当你把对象加入 HashSet 时,HashSet 会先计算对象的 hashcode 值来判断对象加入的位置,同时也会与该位置其他已经加入的对象的 hashcode 值作比较,如果没有相符的 hashcode,HashSet 会假设对象没有重复出现
- 但是如果发现有相同 hashcode 值的对象,这时会调用
equals()
方法来检查 hashcode 相等的对象是否真的相同 - 如果两者相同,HashSet 就不会让其加入操作成功。如果不同的话,就会重新散列到其他位置
- 这样我们就大大减少了 equals 的次数,相应就大大提高了执行速度
hashCode()与 equals()的相关规定
- 两个对象相等,调用 equals 方法必须返回 true
- 两个对象相等,则 hashcode 一定是相同的
- 两个对象有相同的 hashcode,两个对象不一定相等
为什么重写equals()必须也重写hashCode()
- 如果没有重写hashCode(),则会出现调用equals返回true,但是hashcode不相同的情况
- 当放入散列表(HashMap or HashSet)的时候,就会出现重复的key