您的位置 首页 java

面试必问之Java基础:如何判断两个对象相等

重写equals和hashCode

  • 基本概念
  • Object源码
  • 重写equals
  • 重写 hashCode
  • 原理分析
  • hashMap
      • HashMap 组成结构
      • Hash Map的存储

基本概念

  • 要比较两个对象是否相等时需要调用对象的 equals() 方法: 判断对象引用所指向的对象地址是否相等
  • 对象地址相等时, 那么对象相关的数据也相等,包括: 对象句柄对象头对象实例数据对象类型数据
  • 可以通过比较对象的地址来判断对象是否相等

Object源码

  • 对象在不重写的情况下使用的是 Object 中的 equals() 方法和 hashCode() 方法 equals(): 判断的是两个对象的引用是否指向同一个对象 hashCode(): 根据对象地址生成一个整数数值
  • Object hashcode () 方法修饰符为 native: 表明该方法是由操作系统实现. Java调用操作系统底层代码获取 Hash

重写equals

  • 重写equals()方法的场景: 假设现在有很多学生对象默认情况下,要判断多个学生对象是否相等,需要根据地址判断:若对象地址相等,那么对象实例的数据一定是一样的判断相等的要求:当学生的姓名,年龄,性别相等时,认为对象是相等的,不一定需要对象的地址完全相同
  • 根据需求重写equals()方法:
  • 重写了 equals() 方法后,这里会输出 [s1==s2]
  • 如果没有重写 equals() 方法,那么必定会输出 [s1!=s2]

重写hashCode

  • 根据重写equals的方法,上述s1和s2认为是相等的
  • Object中的hashCode()方法: equals() 方法没被修改的前提下,多次调用同一个对象的 hashCode() 方法返回的值必须是相同的整数如果两个对象互相 equals(), 那么这两个对象的 hashcode 值必须相等为不同的对象生成不同的 hashcode 可以提升 Hash 表的性能
  • 在两个对象相等的情况下,分别放入Map和Set中
  • 如果没有重写 Object hashCode() 方法,这是不符合预期的,因为Set容器有去重的特性.相等的元素不会重复显示.这就涉及到Set的底层实现了
  • HashSet底层实现:HashSet 底层是通过 HashMap 实现的比较 Set 容器内元素是否相等是通过比较对象的 hashcode 来判断是否相等的
  • hashCode()的写法: 首先整理出判断对象相等的属性然后去一个尽可能小的正整数,防止最终结果超出整型 int 的取数范围然后计算[正整数 * 属性的hashCode + 其余某个属性的hashCode]重复步骤

原理分析

  • 因为没有重写父类的 Object hashCode() 方法,所以 Object hashCode() 方法会根据两个对象的地址生成相应的 hashcode
  • 由于两个对象分别是实体类创建的不同的实例,所以地址肯定是不一样的,那么 hashcode 值也是不一样的
  • Set区别对象是不是唯一的标准: 两个对象的 hashcode 值是否一样然后再判定两个对象是否 equals
  • Map区别对象是不是唯一的标准: 先根据 Key 值的 hashcode 分配来获取保存数组下标然后再根据 eaquals 区分是否是唯一值

HashMap

HashMap组成结构

  • HashMap: 是由 数组 链表 组成的

HashMap的存储

  • HashMap的存储: 一个对象存储到 HashMap 中的位置是由 key hashcode 值决定的 HashMap查找key: 查找 key ,hashMap 会先根据 key 值的 hashcode 经过取余算法定位所在数组的位置然后根据 key equals 方法匹配相同的 key 值获取相应的对象
  • 存值规则: Key hashcode HashMap 的容量,进行 取余 运算得出该 Key 存储在数组所在位置的下标
  • HashMap查找key: 得到 key 在数组中的位置匹配得到对应 key 值对象然后将上述多个对象根据 key.equals() 来匹配获取对应的key的数据对象
  • HashMap中的hashCode: 如果没有 hashcode 就意味着 HashMap 存储的时候是没有规律可循的这样每次使用 map.get() 方法,就要将map里的对象一一进行 equals 匹配,导致效率低下

文章来源:智云一二三科技

文章标题:面试必问之Java基础:如何判断两个对象相等

文章地址:https://www.zhihuclub.com/190633.shtml

关于作者: 智云科技

热门文章

网站地图