• java面试强基(7)


     

    hashCode() 有什么用?

    ​ hashCode() 的作用是获取哈希码(int 整数),也称为散列码。这个哈希码的作用是确定该对象在哈希表中的索引位置。

    ​ hashCode()定义在 JDK 的 Object 类中,这就意味着 Java 中的任何类都包含有 hashCode() 函数。

    ​ 散列表存储的是键值对(key-value),它的特点是:能根据“键”快速的检索出对应的“值”。这其中就利用到了散列码!(可以快速找到所需要的对象)

    为什么要有 hashCode?

    ​ 其实, hashCode() 和 equals()都是用于比较两个对象是否相等。

    ​ 那为什么 JDK 还要同时提供这两个方法呢?

    ​ 这是因为在一些容器(比如 HashMapHashSet)中,有了 hashCode() 之后,判断元素是否在对应容器中的效率会更高(参考添加元素进HashSet的过程)!

     hashCode 有多个对象,它会继续使用 equals() 来判断是否真的相同。也就是说 hashCode 帮助我们大大缩小了查找成本。

    ​ 那为什么不只提供 hashCode() 方法呢?

    ​ 这是因为两个对象的hashCode 值相等并不代表两个对象就相等。

    ​ 那为什么两个对象有相同的 hashCode 值,它们也不一定是相等的?

    ​ 因为 hashCode() 所使用的哈希算法也许刚好会让多个对象传回相同的哈希值。越糟糕的哈希算法越容易碰撞,但这也与数据值域分布的特性有关(所谓哈希碰撞也就是指的是不同的对象得到相同的 hashCode )。

    总结下来就是 :

    • 如果两个对象的hashCode 值相等,那这两个对象不一定相等(哈希碰撞)。
    • 如果两个对象的hashCode 值相等并且equals()方法也返回 true,我们才认为这两个对象相等。
    • 如果两个对象的hashCode 值不相等,我们就可以直接认为这两个对象不相等。

    为什么重写 equals() 时必须重写 hashCode() 方法 

    因为两个相等的对象的 hashCode 值必须是相等。也就是说如果 equals 方法判断两个对象是相等的,那这两个对象的 hashCode 值也要相等。

    ​ 如果重写 equals() 时没有重写 hashCode() 方法的话就可能会导致 equals 方法判断是相等的两个对象,hashCode 值却不相等。

    总结 :

    • equals 方法判断两个对象是相等的,那这两个对象的 hashCode 值也要相等。
    • 两个对象有相同的 hashCode 值,他们也不一定是相等的(哈希碰撞)。

    官方文档说的是通常有必要需要重写,但其实说必须重写也没有问题,因为你并不能百分百确定这个类之后是否会在HashSet, Hashtable, HashMap等等这些本质是散列表的数据结构中用到。但要记住的是,在没有散列表的情况下,hashCode和equals其实是没有关系的,hashcode并没有什么作用。 

  • 相关阅读:
    Java版企业电子招标采购系统源码Spring Cloud + Spring Boot +二次开发+ MybatisPlus + Redis
    WebRTC音视频开发读书笔记(四)
    volatile和原子量atomic如何对抗编译器优化?
    J2EE--通用分页
    Django部署vue项目报错:Not Found The requested resource was not found on this server.
    JVM-GC-基础知识
    多线程的概念(多线程的代码实现)
    基于Springboot+Vue开发建筑工地用料管理系统
    智能机器人云控平台
    上海市青少年算法2022年11月月赛(丙组)
  • 原文地址:https://blog.csdn.net/m0_62436868/article/details/127957553