== 和 equals 最大的区别: == 是运算符,equals是方法;
== | 是运算符 |
情况 1 | 如果比较的对象是基本数据类型,则比较的是数值大小是否相等 |
情况 2 | 如果比较的对象是引用数据类型,则比较的是对象的地址值是否相等 |
equals() : 用来比较两个对象的内容是否相等
但equals()一般有两种使用情况:
情况 1:类没有重写 equals() 方法和 hashCode() 方法。
如果类没有重写 equals() 方法,则比较的是两个对象的地址值。等价于通过“==” 来比较的是引用数据类型,则比较的是对象的地址值是否相等。
情况 2:类重写 equals() 方法和 hashCode() 方法。
如果类重写 equals() 方法,则比较的是两个对象的内容相等;若它们的内容相等,则返回 true (即认为这两个对象相等),反之,则返回 false。
equals()注意事项
1. equals() 方法不能用于比较 基本数据类型的变量2. String 中的equals() 方法是被重写过的 ,因为 object 的 equals() 方法是比较的对象的内存地址, 而 String 的equals() 方法比较的是对象的内容是否相等 。 当创建 String 类型的对象时,虚拟机会在常量池中查找有没有已经存在的值和要创建的值相 同的对象,如果有就把它赋给当前引用。如果没有就在常量池中重新创建一个 String 对象。
lntellij IDEA中快捷键:同时选择alt+insert后,再选中 equals() and hashCode() 确认
为什么重写 equals() 方法时必须重写 hashCode() 方法?
hashCode()介绍
hashCode() 的作用是获取哈希码,也称为散列码; 哈希码的作用是确定该对象在哈希表中的索引位置。 散列表存储的是键值对(key-value) ,它的特点是:能根据 “ 键 ” 快速的检索出对应的 “ 值 ” 。这其中就 利用到了散列码!(可以快速找到所需要的对象)
为什么要有 hashCode()
当你把对象加入 HashSet 时,先计算对象的 hashcode 值来判断对象加入的位置,同时也 会与其他已经加入的对象的 hashcode 值作比较,如果没有相符的 hashcode , HashSet 会假设对象 没有重复出现。但是如果发现有相同 hashcode 值的对象,这时会调用 equals() 方法来检查 hashcode 相等的对象是否真的相同。如果两者相同,HashSet 就不会让其加入操作成功。如果不同的话,就会重新散列到其他位置。这样我们 就大大减少了 equals 的次数,相应就大大提高了执行速度。
hashCode()与 equals()的相关规定
因为有强制的规范指定需要同时重写 hashcode 与 equal 是方法,许多容器类,如 HashMap、HashSet 都依赖于 hashcode 与 equals 的规定。如果两个对象相等,则 hashcode 一定也是相同的两个对象相等,对两个对象分别调用 equals 方法都返回 true两个对象有相同的 hashcode 值,它们也不一定是相等的因此, equals 方法被覆盖过,则 hashCode 方法也必须被覆盖hashCode() 的默认行为是对堆上的对象产生独特值。如果没有重写 hashCode() ,则该 class 的两个 对象无论如何都不会相等(即使这两个对象指向相同的数据)