private transient HashMap<E,Object> map;
private static final Object PRESENT = new Object();
public static void main(String[] args)
{
Set<Person> set = new HashSet<Person>();
Person p1 = new Person("唐僧","pwd1",25);
Person p2 = new Person("孙悟空","pwd2",26);
Person p3 = new Person("猪八戒","pwd3",27);
set.add(p1);
set.add(p2);
set.add(p3);
System.out.println("总共有:"+set.size()+" 个元素!"); //结果:总共有:3 个元素!
p3.setAge(2); //修改p3的年龄,此时p3元素对应的hashcode值发生改变
set.remove(p3); //此时remove不掉,造成内存泄漏
set.add(p3); //重新添加,居然添加成功
System.out.println("总共有:"+set.size()+" 个元素!"); //结果:总共有:4 个元素!
for (Person person : set)
{
System.out.println(person);
}
}
由于hashset中使用代理hashmap实现的所以向set中插入一个元素后再改变这个元素,这个时候元素的hashcode改变了但却已经插入了,就相当于向错误的槽中插入了一个元素,所以无法remove而改变后的元素由于hashcode变了可以再次插入到表中,那么可能有多可Entry对象指向同一个对象。