HashMap,你是怎么做到的Key重复?,Java高级工程师进阶学习—Java热修复原理

本文通过一段Java代码展示了HashMap中Key重复的问题,探讨了equals()和hashCode()方法在对象存储时的作用。通过分析HashMap的putVal()方法源码,解释了为何对象相等但无法获取到对应值的现象,并提醒读者注意对象的equals()和hashCode()方法的正确实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public static void main(String[] args) {

Student student1 = new Student(1,“小朱”);

Student student2 = new Student(2,“大牛”);

HashMap<Student,String> hashMap = new HashMap<>();

hashMap.put(student1,“菜鸡”);

hashMap.put(student2,“大神”);

//这个方法不需要穿Student,为了验证是同一个对象所以改动了一下

updateValue(hashMap,student1);

System.out.println(hashMap.size());

}

public static HashMap<Student,String> updateValue(HashMap<Student,String> hashMap,Student student){

Student student1 = new Student(1,“小朱”);

System.out.println(student1.equals(student));

hashMap.put(student1,“新手”);

return hashMap;

}

}

复制代码

运行结果

true

3

复制代码

小朱: 代码就是这样,为了验证这个两个对象是相同的,我该遭了updateValue方法.本来只要传HashMap<Student,String>,为了验证我外加了一个Student.

大牛: 哦,确实有意思,你怎么不尝试写个取出元素的方法,例如:

getValue

public static void getValue(HashMap<Student,String> hashMap){

Student student1 = new Student(1,“小朱”);

System.out.println(hashMap.get(student1));

}

复制代码

小朱: 我试下.

输出结果

null

复制代码

小朱: 为什么?我重写了equals它们对象都相等啊?为什么取不出来!

大牛: HashMap源码了解一下.

public V put(K key, V value) {

return putVal(hash(key), key, value, false, true);

}

/**

  • Implemen

《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》

【docs.qq.com/doc/DSmxTbFJ1cmN1R2dB】 完整内容开源分享

ts Map.put and related methods.

  • @param hash hash for key

  • @param key the key

  • @param value the value to put

  • @param onlyIfAbsent if true, don’t change existing value

  • @param evict if false, the table is in creation mode.

  • @return previous value, or null if none

*/

final V putVal(int hash, K key, V value, boolean onlyIfAbsent,

boolean evict) {

Node<K,V>[] tab; Node<K,V> p; int n, i;

if ((tab = table) == null || (n = tab.length) == 0)

n = (tab = resize()).length;

if ((p = tab[i = (n - 1) & hash]) == null)

tab[i] = newNode(hash, key, value, null);

else {

Node<K,V> e; K k;

if (p.hash == hash &&

((k = p.key) == key || (key != null && key.equals(k))))

e = p;

else if (p instanceof TreeNode)

e = ((TreeNode<K,V>)p).putTreeVal(this, tab, hash, key, value);

else {

for (int binCount = 0; ; ++binCount) {

if ((e = p.next) == null) {

p.next = newNode(hash, key, value, null);

if (binCount >= TREEIFY_THRESHOLD - 1) // -1 for 1st

treeifyBin(tab, hash);

break;

}

if (e.hash == hash &&

((k = e.key) == key || (key != null && key.equals(k))))

break;

p = e;

}

}

if (e != null) { // existing mapping for key

V oldValue = e.value;

if (!onlyIfAbsent || oldValue == null)

e.value = value;

afterNodeAccess(e);

return oldValue;

}

}

++modCount;

if (++size > threshold)

resize();

afterNodeInsertion(evict);

return null;

}

复制代码

大牛: 还有下面这段.

public static void main(String[] args) {

Student student1 = new Student(1,“小朱”);

Student student2 = new Student(1,“小朱”);

System.out.println(student1.equals(student2));

System.out.println(student1.hashCode());

System.out.println(student2.hashCode());

}

复制代码

小朱: 我跑一下看看.

true

1456208737

288665596

复制代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值