拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...
推荐你看下Map的原理map在存放值的时候不是用的对象的地址,而是用的对象的hashcode你先将p1作为key放进map,然后更改了p1的值,这时候p1的hashcode已经改变了,再次存放时map以为是不同的key,所以就存进去了。
以下是HashMap.put的内部实现
public V put(K key, V value) { return putVal(hash(key), key, value, false, true); }
p1.setAge(5)之后p1的hashCode就改变了,上述函数中hash(key)就发生了变化,虽然key是相同的对象,但是HashMap还是将其作为一个新key存储了。
出于效率的考虑,这种场景就不被支持了。算是是HashMap的一个坑吧。
推荐你看下Map的原理
map在存放值的时候不是用的对象的地址,而是用的对象的hashcode
你先将p1作为key放进map,
然后更改了p1的值,这时候p1的hashcode已经改变了,再次存放时map以为是不同的key,所以就存进去了。
以下是HashMap.put的内部实现
p1.setAge(5)之后p1的hashCode就改变了,上述函数中hash(key)就发生了变化,虽然key是相同的对象,但是HashMap还是将其作为一个新key存储了。
出于效率的考虑,这种场景就不被支持了。算是是HashMap的一个坑吧。