Hashcode 散列码

一个类A没有重写hashCode()方法,那么它使用Object的hashCode()方法生成散列码,即用对象的内存地址计算散列码

所有有“Hash”字样的类都涉及到hashcode,如HashMap,HashSet。所以要使用这些容器存储对象,必须同时重写hashCode() 和equals()。否则一个类的两个对象objA 与objB,满足objA.equals(objB)为真,放到HashSet<>容器中是不会自动去重的。

微笑问:如何编写hashCode()?

答:equals(Object obj)方法中用于比较的字段,都应该参与hashCode()的计算。也就是说,一个类的两个对象objA 与objB,若objA.equals(objB)为真,则objA.hashCode()==objB.hashCode()也应该为真。


注意hashCode的可变性。

HashMap在内部使用哈希表实现了对键的对应值的快速查找。但是这里也有一个小问题:支持哈希码的键依赖于可变字段的内容,这样容易产生 bug,即使最耐心的 Java 开发人员也会被这些 bug 逼疯。

下例中的 Person 对象有一个常见的 hashCode() ,它使用 firstName、lastName 和 age 字段 ( 所有字段都不是 final 字段 )计算 hashCode(),对 Map 的 get() 调用会失败并返回 null。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值