HashCode重载不当造成内存泄漏

 java.util.HashSet;
java.util.Set;

HashTest {

main(String[] args){
Set hashSet = HashSet();
Student student = Student();
student.setName();
student.setNo();
hashSet.add(student);
student.setName();
isOk = hashSet.contains(student);
System.out.println(isOk);
hashSet.add(student);
size =hashSet.size();
System.out.println(size);
hashSet.remove(student);
size =hashSet.size();
System.out.println(size);

}


}
Student {

Student(){
}

String name;
String no;

String getName() {
name;
}


String getNo() {
no;
}

setName(String string) {
name = string;
}

setNo(String string) {
no = string;
}

hashCode() {
no.hashCode()+name.hashCode();
}

}

执行一下上面的程序,其结果可能有点出乎你的意料。

如果Set声明为一个类的static成员,那么hashSet就会始终持“被遗忘”的对象,直到程序退出。

如过类似的代码运行在服务器端,其结果就可想而知了。
不要以为这种情况不常见,这是Java中最导致内存泄漏的最好办法。
比如Hibernate中生成的那些PO,如果在操作的过程中修改了影响生成hashcode的字段,
而Hibernate运用了缓存机制,相信,运行一段时间之后,你的程序不出现OutOfMemory才怪呢!
阅读更多

没有更多推荐了,返回首页