这两天在做项目的时候,根据几个条件查询结果,查询条件一样,多次点击查询,在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);
}
}
请大家帮忙查找原因,谢谢
刚刚出现了这个问题,如下图
- 大小: 18.5 KB
分享到:
相关推荐
"Java.lang.OutOfMemoryError: Java heap space 解决方法" Java.lang.OutOfMemoryError: Java heap space 是 Java 中的一个常见错误,它发生时,Java 虚拟机 (JVM) 无法分配对象,因为堆空间不足。下面是解决该问题...
### Java 错误处理:java.lang.OutOfMemoryError: Java heap space 在Java应用程序开发过程中,经常遇到的一个问题就是内存溢出错误,特别是在处理大量数据或长时间运行的应用时。其中,“java.lang....
### Myeclipse下java.lang.OutOfMemoryError: Java heap space的解决方案 在使用Myeclipse进行Java开发时,可能会遇到`java.lang.OutOfMemoryError: Java heap space`这个错误提示。这种异常通常发生在应用程序占用...
### 编译时出现java.lang.OutOfMemoryError Java heap space异常 #### 一、问题概述 在进行Java项目编译的过程中,可能会遇到`java.lang.OutOfMemoryError: Java heap space`这种异常。这类异常通常表明Java虚拟机...
Java程序在运行过程中可能会遇到各种异常,其中"nested exception is java.lang.OutOfMemoryError: Java heap space"是一个常见的问题,通常发生在程序试图分配超过堆内存限制的空间时。这个错误表明Java虚拟机(JVM...
当程序创建的对象过多或单个对象占用内存过大时,如果没有足够的空闲内存来分配新对象,JVM就会抛出“OutOfMemoryError: Java heap space”错误。这可能是由于以下原因造成的: 1. **初始堆大小设置不当**:默认...
java虚拟机OutOfMemoryError:Java heap space堆dump文件,可以直接用来分析。
在 Java 应用程序运行过程中,如果出现内存不足的情况,JVM(Java虚拟机)会抛出 `java.lang.OutOfMemoryError: Java heap space` 的异常。这种错误通常发生在应用程序对内存的需求超过了 JVM 能够提供的最大堆空间...
当程序创建新的对象并分配给堆时,如果堆空间不足,就会抛出`OutOfMemoryError: Java heap space`异常。Java应用程序可以通过设置JVM的启动参数来控制堆的大小,例如`-Xms`和`-Xmx`分别用于设置初始堆大小和最大堆...
在Java程序中,`java.lang.OutOfMemoryError: Java heap space` 是一个常见的错误,意味着程序在运行过程中耗尽了JVM分配的堆内存。这个错误通常发生在创建大量对象或者单个对象占用过多内存时。 一、问题描述与...
### Java.lang.OutOfMemoryError:Java Heap Space 错误及处理办法 在Java应用程序开发与维护过程中,经常会遇到`java.lang.OutOfMemoryError: Java heap space`这一异常情况。该异常通常表明Java虚拟机(JVM)的堆...
在Java应用程序运行过程中,经常会遇到一个常见的错误提示:`java.lang.OutOfMemoryError: Java heap space`。这通常意味着Java虚拟机(JVM)的堆内存空间不足,无法满足当前程序运行的需求。这种问题常见于服务器端...
当应用程序创建大量对象,且这些对象生命周期较长,或者无法及时释放时,可能会导致堆内存溢出,表现为`java.lang.OutOfMemoryError: Java heap space`。为了解决这个问题,可以通过`-Xms`和`-Xmx`参数来设置堆的...
java.lang.OutOfMemoryError: Java heap space 解决方法
在Tomcat中java.lang.OutOfMemoryError: Java heap space异常处理: 1. Heap size JVM堆的设置是指Java程序运行过程中JVM可以调配使用的内存空间的设置。 2. JVM在启动的时候会自动设置Heap size的值,其初始空间...
Eclipse 中通过 Tomcat 运行 J2EE 项目 java.lang.OutOfMemoryError PermGen space 的解决方案 在 Eclipse 中通过 Tomcat 运行 J2EE 项目时,可能会出现 java.lang.OutOfMemoryError: PermGen space 异常,这是由于...
1. Java堆内存溢出(Java heapspace) Java堆内存主要存储对象实例,其大小通过JVM启动参数-Xmx来限制。当堆内存不足以容纳新对象时,就会抛出java.lang.OutOfMemoryError: Java heap space错误。常见的解决方法是...
- **错误日志**:`java.lang.OutOfMemoryError: Java heap space` 和 `java.lang.OutOfMemoryError: GC overhead limit exceeded` - **原因**:创建大量对象或者内存泄露可能导致Java堆空间不足。例如,大数据加载...