hashCode的作用

雨点打透心脏的1/2处 2022-05-09 01:18 322阅读 0赞
  1. hashCode方法是在Object中定义的
  2. Java中的集合(Collection)有两类,一类是List,再有一类是Set
  3. 前者集合内的元素是有序的,元素可以重复;后者元素无序,但元素不可重复。
  4. 要想保证元素不重复,可两个元素是否重复应该依据什么来判断呢? 这就是Object.equals方法了
  5. 但是,如果每增加一个元素就检查一次,那么当元素很多时,后添加到集合中的元素比较的次数就非常多
  6. 了。
  7. 也就是说,如果集合中现在已经有1000个元素,那么第1001个元素加入集合时,它就要调用1000equals
  8. 法,这会大大降低效率。
  9. 于是,Java采用了哈希表的原理。哈希(Hash)实际上是个人名,由于他提出一哈希算法的概念,所以就以他的名字命名了。
  10. 哈希算法也称为散列算法,是将数据依特定算法直接指定到一个地址上。
  11. 初学者可以这样理解,hashCode方法实际上返回的就是对象存储的物理地址(实际可能并不是)
  12. 这样一来,当集合要添加新的元素时,先调用这个元素的hashCode方法,就一下子能定位到它应该放置的物理位置上。
  13. 如果这个位置上没有元素,它就可以直接存储在这个位置上,不用再进行任何比较了
  14. 如果这个位置上已经有元素了, 就调用它的equals方法与新元素进行比较,相同的话就不存了,不相同就散列其它的地址。
  15. 所以这里存在一个冲突解决的问题。这样一来实际调用equals方法的次数就大大降低了,几乎只需要一两次。

发表评论

表情:
评论列表 (有 0 条评论,322人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Hashcode作用

    `hashCode()` 是 Java 中一个非常重要的方法,其主要作用如下: 1. 数据存储:在 Java 中,`hashCode()` 方法通常用于在哈希表(如 Has

    相关 Hashcode作用

    以下都是Java的基础面试题,相信大家都会有种及眼熟又陌生的感觉、看过可能在短暂的面试后又马上忘记了。JavaPub在这里整理这些容易忘记的重点知识及解答,`建议收藏,经常温习

    相关 Hashcode作用

    关于Hashcode的作用     总的来说,Java中的集合(Collection)有两类,一类是List,再有一类是Set。前者集合内的元素是有序的,元素可以重复;后者