博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hashCode到底有什么用?
阅读量:2001 次
发布时间:2019-04-28

本文共 946 字,大约阅读时间需要 3 分钟。

转载自 

hashCode概念


hashCode是jdk根据对象的地址算出来的一个int数字,即对象的哈希码值,代表了该对象在内存中的存储位置。


我们都知道hashCode()方法是顶级类Object类的提供的一个方法,所有的类都可以进行对hashCode方法重写。


我们也知道在比较一个类是否相同时往往会重写equals方法,值得注意的是,重写equals方法的同时必须也要重写hashCode方法,多次调用一个对象的hashCode方法必须返回同一个数字,这也是必须遵守的规范,不然会造必须存在的危害。


hash冲突


当两个对象equals相同,hashCode规定也必须相同,但反过来就不一定,两个对象对应一个hashCode,但equals却并不相等。。这就是传说中的hash冲突。HashMap是以hashCode取模数组形式存放值的,那两个对象hashCode一样会不会造成前一个对象的值覆盖呢?答案是不会,因为它采用了另外一种链表数据结构来解决hash冲突的情况,即使两个对象的hashCode一样,它们会放到当前数组索引位置的链表中。


hashCode设计


HashSet通过HashMap来实现的,用来存储不重复数据的,怎么判断里面的对象是否重复呢?判断对象是否重复即是判断对象里面的属性是否都一样,这时必须是重写了equals方法去比较对象的里面所有的值,而不是比较引用地址,比较引用地址它们永远都不相等,除非是同一个对象。通过equals比较的过程性能是非常不佳的,所以有了hashCode这个设计,简单两个数字的比较性equals没法比的,所以可以先通过比较对象的hashCode是否一样确定是不是同一个对象,如果hashCode不一样这时肯定就不是同一个对象,反之如果hashCode一样而且equals或者==也一样这肯定就是同一个对象。所以先比较数字的hashCode再比较equals或者==,这样效率会明显提升。


假如我们重写了equals而不重写hashCode方法,多个对象属性值一样的它们的hashCode肯定是不一样的,这时作为key在put到map中的时候,就会有多个这样的key,而达不到对象作为key的场景,同样也达不到HashSet去重的效果。

你可能感兴趣的文章
iOS开发------程序实现国际化Localizable
查看>>
SDWebImage 原理及使用
查看>>
iOS Runloop详细介绍及应用示例(持续更新)
查看>>
iOS runloop与定时器的使用
查看>>
GCD定时器使用笔记 及 详细分析
查看>>
@property (nonatomic, strong) NSString *str有什么问题
查看>>
结合一道面试题 看c语言运算符的执行顺序
查看>>
Objective-C的内省方法介绍
查看>>
Objective-C 内存管理 看这个就够啦
查看>>
IOS开发--微信支付
查看>>
iOS 微信支付 实用教程
查看>>
UIViewController的基本概念与生命周期
查看>>
最新方法制作自己的cocoapods开源框架的详细步骤
查看>>
Getting start with OCMock in you unit test
查看>>
李洪强和你一起学习前端之(1)Html基础
查看>>
李洪强iOS经典面试题142-第三方框架及其管理
查看>>
李洪强经典面试题38
查看>>
我们必须自学
查看>>
iOS应用内付费(IAP)开发步骤列表
查看>>
iOS-TextField知多少
查看>>