zoukankan      html  css  js  c++  java
  • hashcode的作用

    根据官方文档,我们可以抽成以下的几个关键点:

      1.hashCode的存在主要是用于查找的快捷性,如hashtable,hashMap等,hashCode是用来

       在散列存储结构中确定对象的存储地址的

      2.如果两个对象相同,就要适用于equals(java.lang.Object)方法,那么这两个对象的hashCode一定

       相同

      3.如果对象的equals方法被重写,那么hashCode也尽量重写,并且产生hashCode使用的对象,一定要
       和equals方法中使用的一致,否则就会违法上面的第二条

      4.两个对象的hashCode相同,并不表示这两个对象相同,也就不一定适用于equals(java.lang.object)

       方法,只能够说明这两个对象在三列存储结构中,如hashtable,他们"存放于同一个篮子里面"

       补充:如果对于两个对象,如果没有重写hashCode(),则此时的hashCode()就是其存储地址

      注意:

        如果你在一个对象中,重写了equals()方法,但是对于你补充些hashCode()方法,会造成问题

        1.如果你比较两个对象,看这两个对象是否相同,但是这两个对象比较之前,会比较hashCode(),

        如果你没写,则这两个对象不相等

        2.如果你在Map<Object,Value>,你此时重写了Object的equals(),但是你没有hashCode(),

        则此时你想通过key(Object)想得到这个value,但是你在这两个对象是会比较这两个对象(key)

        相等,但此时一定会先比较这个对象的hashCode(),一般来说是不同,但此时判断这两个对象不同,

        hashCode()不同,则对对象一定不同

  • 相关阅读:
    大型网站数据库架构分析
    Mysql 存储引擎中InnoDB与Myisam的主要区别
    设计模式培训之一:为什么要用单例模式?
    架构师成长之路
    hdoj1257 最少拦截系统
    hdoj2571 命运
    hdoj1010 Temperor of the bone
    hdoj1175 连连看
    ny220 推桌子
    ny168 房间安排
  • 原文地址:https://www.cnblogs.com/wnbahmbb/p/6271504.html
Copyright © 2011-2022 走看看