拥有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的一個坑吧。