这个问题很好回答,key肯定是不能重复,如果两个value的key相同,到时候就无法准确读取value值了
本质上相同不代表“表面上”不可以相同,下面请看“表面上”相同key但是不同value的例子
class A{
private String code;
private String name;
@Override
public int hashCode() {
// TODO Auto-generated method stub
return code.hashCode()+name.hashCode();
}
public String getCode() {
return code;
}
public void setCode(String code) {
this.code = code;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
// TODO Auto-generated method stub
return code.toString()+name.toString();
}
}
public static void testHashMap(){
Map<A,String> map = new HashMap<A,String>();
A a1 = new A();
a1.setCode("123");
a1.setName("456");
map.put(a1, "test1");
System.out.println(map);
a1.setCode("789");
map.put(a1, "test2");
System.out.println(map);
}
输出结果{123456=test1}
{789456=test1, 789456=test2}
会发现“表面上”是相同的,出现这种结果本质原因是在于tostring方法的转化,但是它们在hashmap数据结构中hashcode是不一样,所以对应的key也是不一样的。
本文通过一个具体的Java示例展示了如何使用HashMap存储看似相同但实际不同的键值对。通过自定义类并重写hashCode和toString方法,实现了表面上相同的键却能正确地存储不同的值。
5万+

被折叠的 条评论
为什么被折叠?



