• 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并没有什么作用。 

  • 相关阅读:
    STM32笔记
    量子点表面修饰PEG/抗体/金属/细胞膜/无机材料标记与制备
    CYEZ 模拟赛 6
    刷爆力扣之最短无序连续子数组
    初识网络
    高级测试:如何使用Flink对Strom任务的逻辑功能进行复现测试?
    Halcon (4):如何开始自学
    JavaSE——字符串常量池(StringTable)
    SpringMVC controller方法获取请求数据与前端传参类型匹配
    Java-调用R语言和调用Python(前后端展示)
  • 原文地址:https://blog.csdn.net/m0_62436868/article/details/127957553