HashCode重载不当造成内存泄漏

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

/**
 *如果hashCode的方法重载不当,很容易造成内存泄漏,特别是当Set为静态的时候
 *并且,中间容易出现奇怪的现象,明明已经添加到Set当中,但是contains方法却返回false 
 */
public class HashTest {

    public static void main(String[] args){
        Set hashSet = new HashSet();
        Student student = new Student();
        student.setName("a");
        student.setNo("M");
        hashSet.add(student);
        student.setName("aaaaa");
        boolean isOk = hashSet.contains(student);               
        System.out.println(isOk);       
        hashSet.add(student);
        int size =hashSet.size();
        System.out.println(size);
        hashSet.remove(student);
        size =hashSet.size();
        System.out.println(size);
        
    }
    

}
class Student {
    
        public Student(){
        }

        private String name;
        private String no;

        public String getName() {
            return name;
        }


        public String getNo() {
            return no;
        }

        public void setName(String string) {
            name = string;
        }

        public void setNo(String string) {
            no = string;
        }
        
        public int hashCode() {
            return no.hashCode()+name.hashCode();
        }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值