java heap space outOfMemoryError

这两天在做项目的时候,根据几个条件查询结果,查询条件一样,多次点击查询,在firebug里面看响应时间慢慢增加,最后居然要20多秒, 导致流产,后台报如题错误,内存溢出了。

 

这个情况也有些不稳定,有时候会出现这种问题

 

数据库的记录不多,95条记录,所以排除了结果数太多导致的内存溢出原因

主要关联到了3个表:LimsDeteContractSample a、LimsDeteSampleDictionary b、LimsDeteModelSpecification c

a<-->b 多对多关系

b<-->c一对多关系

 

hibernate在加载a的时候,同时会吧b、c都load出来,所以,我在找出95条a记录时,同时会去load b和c,这样导致返回list集合的响应时间比较长,但我觉得这个还不至于导致多次查询最终内存溢出。

我在代码里进行循环的时候还用的了HashMap,查看资料说内存溢出与HashMap中的对象没有被及时销毁有关系,后来尝试使用WeakHashMap替代了HashMap,也没有解决问题。

我也知道可以再Eclipse设置JVM的内存大小,但我不觉得是由于内存不够导致的内存溢出,应该是内存泄露吧。

但苦苦没有发现原因。

 

后查询台代码如下:

sqlBuf.append("select {ldcs.*} from lims_dete_contract_sample ldcs ");
sqlBuf.append(" join lims_dete_sample_dictionary dic on dic.class2 = ldcs.sample_id");
sqlBuf.append(" join lims_dete_model_specification model on model.model_id = ldcs.model_id");
sqlBuf.append(" join lims_dete_contract ldc on ldc.contract_id = ldcs.contract_id ");
sqlBuf.append(" join lims_customer entrust on entrust.customer_id = ldc.commissioned_customer_id");
sqlBuf.append(" join lims_customer product on product.customer_id = ldc.production_customer_id");
//后面会插入简单where语句  
//下面把查询出来的list遍历,把满足条件的放入HashMap里面,最后遍历map返回结果就ok了
List<LimsDeteContractSample> csList = hibernateTemplateDAO.createSQLQuery(sqlBuf.toString()).addEntity("ldcs",LimsDeteContractSample.class).list();
  //List<LimsDeteContractSample> csList = hibernateTemplateDAO.find("from LimsDeteContractSample");
  Map<LimsDeteContractSample,Integer> ldcsMap = new HashMap<LimsDeteContractSample,Integer>();
  Set<LimsDeteContractSampleReceive> recSet = null;
  int recNum = 0;
  if(csList != null && csList.size() > 0){
   for(LimsDeteContractSample cs : csList){
    recSet = cs.getLimsDeteContractSampleReceives();
    recNum = 0;
    for(LimsDeteContractSampleReceive rec : recSet){
     recNum += rec.getReceiveNumber();
    }
    if(cs.getContractAmount() > recNum)
     ldcsMap.put(cs, recNum);
   }
  }

 请大家帮忙查找原因,谢谢

 

刚刚出现了这个问题,如下图

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值