本帖最后由 xuemeng 于 2013-5-21 08:17 编辑
import java.util.HashSet;
public class Demo {
public static void main(String[] args) {
HashSet<Person> hs = new HashSet<Person>();
Person p1 = new Person(5);
Person p2 = new Person(5);
//我们都知道, 当hashCode还有equals相同时, 使用HashSet添加元素, 那么只能成功添加一个, 那么按照我之前的理解,既然是p1先添加进去, 那么p2就没有添加进去, 那么当我用
remove( )方法移除p2元素时, 那么应该要么就是空指针异常, 要么即使不是空指针异常, 那集合的长度也应该是1才对, 然而事实上是, 不论是移除p1元素还是p2元素, 最终打印集合长度都是0, 请问这是为什么? 求解释, 求分析??
hs.add(p1);
hs.add(p2);
// hs.remove(p1);
hs.remove(p2);
System.out.println(hs.size());
}
}
class Person {
private int age;
Person(int age) {
this.age = age;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + age;
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Person other = (Person) obj;
if (age != other.age)
return false;
return true;
}
} |