Java中的hashcode方法
来源:互联网 发布:魔兽争霸3 mac 编辑:程序博客网 时间:2024/05/21 06:52
一.hashCode方法的作用
对于包含容器类型的程序设计语言来说,基本上都会涉及到hashCode。在Java中也一样,hashCode方法的主要作用是为了配合基于散列的集合一起正常运行,这样的散列集合包括HashSet、HashMap以及HashTable。
为什么这么说呢?考虑一种情况,当向集合中插入对象时,如何判别在集合中是否已经存在该对象了?(注意:集合中不允许重复的元素存在)
也许大多数人都会想到调用equals方法来逐个进行比较,这个方法确实可行。但是如果集合中已经存在一万条数据或者更多的数据,如果采用 equals方法去逐一比较,效率必然是一个问题。此时hashCode方法的作用就体现出来了,当集合要添加新的对象时,先调用这个对象的 hashCode方法,得到对应的hashcode值,实际上在HashMap的具体实现中会用一个table保存已经存进去的对象的hashcode 值,如果table中没有该hashcode值,它就可以直接存进去,不用再进行任何比较了;如果存在该hashcode值, 就调用它的equals方法与新元素进行比较,相同的话就不存了,不相同就散列其它的地址,所以这里存在一个冲突解决的问题,这样一来实际调用 equals方法的次数就大大降低了,说通俗一点:Java中的hashCode方法就是根据一定的规则将与对象相关的信息(比如对象的存储地址,对象的 字段等)映射成一个数值,这个数值称作为散列值。
put方法是用来向HashMap中添加新的元素,从put方法的具体实现可知,会先调用hashCode方法得到该元素的hashCode 值,然后查看table中是否存在该hashCode值,如果存在则调用equals方法重新确定是否存在该元素,如果存在,则更新value值,否则将 新的元素添加到HashMap中。从这里可以看出,hashCode方法的存在是为了减少equals方法的调用次数,从而提高程序效率。
对于两个对象,如果调用equals方法得到的结果为true,则两个对象的hashcode值必定相等;
如果equals方法得到的结果为false,则两个对象的hashcode值不一定不同;
如果两个对象的hashcode值不等,则equals方法得到的结果必定为false;
如果两个对象的hashcode值相等,则equals方法得到的结果未知。
二.equals方法和hashCode方法
默认情况 下hashCode方法是将对象的存储地址进行映射。重写equal后未重写hashCode方法会导致对象的hash值不一样,比较时是用两个不同的对象进行比较。
- java中的hashCode方法
- Java中的HashCode方法
- Java中的hashcode方法
- java中的hashcode方法
- Java中的hashcode方法
- Java中的hashcode方法
- Java中的hashcode方法
- Java中的hashcode方法
- Java中的hashcode方法
- Java中的hashcode方法
- 关于java中的hashCode()方法
- 浅谈Java中的hashcode方法
- 浅谈Java中的hashcode方法
- 关于java中的hashCode方法
- 浅谈Java中的hashcode方法
- 浅谈Java中的hashcode方法
- 浅谈Java中的hashcode方法
- 浅谈Java中的hashcode方法
- RC滤波器
- Tab
- hiveserver2 后台运行
- ViewPager无限轮播
- CHAR_LENGTH(str)函数
- Java中的hashcode方法
- 设计模式
- SQL注入limit用法
- 使用依赖添加无线轮播加按钮
- Springboot Dubbo ZooKeeper整合
- OC : NSData (二进制数据流)
- 欢迎使用CSDN-markdown编辑器
- android utils
- ECMAScript 与 JavaScript的联系 以及为什么会有浏览器兼容的问题?