博客
关于我
Java hashcode() 和 equals() 区别
阅读量:378 次
发布时间:2019-03-05

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

hashcode 用于计算对象的 hash 码, 当对象作为 key 用在 HashMap / HashSet 时, 会首先利用 hashcode() 计算对象的 hash 值, 与数组长度取模, 得到所在数组的位置, 是为了提升查找速度

equals 方法是当遇到 hash 碰撞时 (hash 值相同), 会调用 equals 方法具体比较对象是否相等

equals 方法, 默认是比较两个对象 ==, 即内存地址是否相等, 我们可以重写该方法, 例如判断这两个对象的具体字段值是否相等

Object equals

总结:

hashcode 用于在哈希表中, 降低查找对象的成本
equals 用于判断两个对象是否真的相等

转载地址:http://kvcg.baihongyu.com/

你可能感兴趣的文章
MySQL底层概述—3.InnoDB线程模型
查看>>
MySQL底层概述—5.InnoDB参数优化
查看>>
MySQL底层概述—6.索引原理
查看>>
MySQL底层概述—7.优化原则及慢查询
查看>>
MySQL底层概述—8.JOIN排序索引优化
查看>>
MySQL底层概述—9.ACID与事务
查看>>
Mysql建立中英文全文索引(mysql5.7以上)
查看>>
MySQL开源工具推荐,有了它我卸了珍藏多年Nactive!
查看>>
Mysql当前列的值等于上一行的值累加前一列的值
查看>>
MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>
MySQL必知必会(组合Where子句,Not和In操作符)
查看>>
MySQL必知必会总结笔记
查看>>
MySQL快速入门
查看>>
MySQL快速入门——库的操作
查看>>
mysql快速复制一张表的内容,并添加新内容到另一张表中
查看>>
mysql快速查询表的结构和注释,字段等信息
查看>>
mysql怎么删除临时表里的数据_MySQL中关于临时表的一些基本使用方法
查看>>
mysql性能优化
查看>>
MySQL性能优化必备25条
查看>>
Mysql性能优化(1):SQL的执行过程
查看>>