在学习hashset时重写equals时要重写hashcode,一直不明白hashcode里面返回值的意思
3条回答 默认 最新
- threenewbee 2016-08-04 10:08关注
hashcode给比较两个对象是否相等提供了一种快速的方法
我们规定,hashcode相同,对象可以相同,可以不同,但是hashcode不同,对象必然不同。
所以我们在比较两个对象的时候,不需要一个字段一个字段去比较了,可以先比较下hashcode,如果hashcode不同,就知道对象肯定不同。
如果hashcode相同,我们才需要进一步比较。而且如果对象的字段又是对象,那么我们又可以先比较这个字段的hashcode。
比较对象为什么那么重要?因为很多算法都需要,主要是查找算法、数据组织、排序等。
试想,如果我们需要检索一个数组中的一个对象,如果没有hashcode,我们每个都要比较,那么这个运算量就很大了。解决 无用评论 打赏 举报
悬赏问题
- ¥100 Jenkins自动化部署—悬赏100元
- ¥15 关于#python#的问题:求帮写python代码
- ¥20 MATLAB画图图形出现上下震荡的线条
- ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
- ¥15 perl MISA分析p3_in脚本出错
- ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
- ¥15 ubuntu虚拟机打包apk错误
- ¥199 rust编程架构设计的方案 有偿
- ¥15 回答4f系统的像差计算
- ¥15 java如何提取出pdf里的文字?