关于java.lang.OutOfMemoryError

java.lang.OutOfMemoryError这个错误我相信大部分开发人员都有遇到过,产生该错误的原因大都出于以下原因:JVM内存过小、程序不严密,产生了过多的垃圾。  
           在一年多的工作过程中,遇到该问题的印象最深有两次。 

           一次是用hibernate查询数据时,一次查询过多的数据,例如30000条,此时程序出错,该死的java.lang.OutMemoryError,后来调整了该部分的代码,每次只取出指定量的数据,成功的解决该问题。 

            还有一次是当测试人员loadRunner做压力测试时,并发200个用户时,运行不到几分钟整个weblogic都瘫掉,真够狠的,又是java.lang.OutOfMemoryError, PM叫我检查同事写的代码,折腾了我好久,结果发现原来是由于session的资源一直没有被释放产生的,真把俺给气死!!!在该工程中在web.xml文件中设置了一个session的侦听期,当检测到session超时时,进入指定的类进行相应处理,而该同事在进行了自定义的处理后,没有通过session的invalidate()方法将session的资源释放,导致当大批量并发时,造成内存溢出。 

            解决java.lang.OutOfMemoryError的方法有如下几种:  

增加jvm的内存大小。方法有:  
            1)在执行某个class文件时候,可以使用java -Xmx256M aa.class来设置运行aa.class时jvm所允许占用的最大内存为256M。 
            2)对tomcat容器,可以在启动时对jvm设置内存限度。对tomcat,可以在catalina.bat中添加: 
 "set CATALINA_OPTS=-Xms128M -Xmx256M 
  set JAVA_OPTS=-Xms128M -Xmx256M",或者把%CATALINA_OPTS%和%JAVA_OPTS%代替为-Xms128M -Xmx256M 

            3)对resin容器,同样可以在启动时对jvm设置内存限度。在bin文件夹下创建一个startup.bat文件,内容如下: 
                 @echo off 
                  call "httpd.exe"  "-Xms128M" "-Xmx256M" 
                  :end  
                  其中"-Xms128M"为最小内存,"-Xmx256M"为最大内存。 

   2.    优化程序,释放垃圾。 

        主要包括避免死循环,应该及时释放种资源:内存, 数据库的各种连接,防止一次载入太多的数据。导致java.lang.OutOfMemoryError的根本原因是程序不健壮。因此,从根本上解决Java内存溢出的唯一方法就是修改程序,及时地释放没用的对象,释放内存空间。 遇到该错误的时候要仔细检查程序,嘿嘿,遇多一次这种问题之后,以后写程序就会小心多了。 

 

 

 

 

 

关于J2ME开发过程中,也会遇到这个错误,一般是处理图片问题:下面就举个例子:

 

如果加载的图片过大,就可能会出现这样的问题啊,或者加载的歌曲过大,也会出现这样的问题:

 

 

 

 

到底为什么会出现这样的错误,关于Java 虚拟机的内存,有兴趣者请到一下这个网站:

http://www.360doc.com/content/06/0118/14/1137_60104.shtml

<think>嗯,用户问的是Java中的OutOfMemoryError错误的原因和解决方法。我需要先回忆一下相关的知识,并结合提供的引用内容来组织答案。 首先,根据引用内容,这个错误常见的原因包括JVM内存不足、程序不严谨导致内存泄漏或者对象过多,还有资源未及时释放。比如引用1提到程序不健壮,没有及时释放无用对象;引用2提到JVM内存过小和程序问题;引用4也提到物理内存过小,默认的64MB可能不够用。 接下来需要整理原因部分。常见的原因可能有:堆内存不足、内存泄漏、大对象或过多数据加载、Metaspace/PermGen空间不足、线程过多导致栈溢出、直接内存不足等。引用3提到String太大超过JVM内存,引用5提到用HeapDump参数帮助诊断。 解决方法方面,需要包括调整JVM参数(比如-Xmx)、检查内存泄漏、优化代码、处理大文件或数据分页,以及使用工具分析dump文件。引用1和5都提到了调整JVM参数和分析dump,引用4建议增加内存,引用1还提到释放资源。 然后要确保回答结构清晰,分点列出原因和解决方法。同时用户可能需要相关的问题,比如如何诊断内存泄漏,或者不同内存区域溢出的表现。 需要注意的是,用户可能对JVM内存结构不太熟悉,所以在解释原因时可以简要提及堆、栈、Metaspace等区域。另外,引用中多次提到程序问题,比如死循环、未关闭连接,这些需要强调代码优化的重要性。 最后,生成的相关问题要围绕用户可能进一步想知道的内容,比如具体参数设置、工具使用、不同错误类型等。确保引用标记正确,比如引用1到5的信息要对应到正确的位置。</think>### Java.lang.OutOfMemoryError 原因及解决方案分析 #### 一、核心原因 1. **JVM内存分配不足** - 默认堆内存较小(如64MB),无法满足应用需求[^4] - 未根据业务场景合理设置`-Xmx`(最大堆内存)和`-Xms`(初始堆内存)参数 2. **内存泄漏(Memory Leak)** - 未释放无用对象(如静态集合持续增长)[^1] - 资源未关闭(数据库连接、文件流未释放)[^1] 3. **大对象/过量数据加载** - 一次性加载超大文件到内存(如数GB的CSV文件) - 不合理缓存策略(如使用`String`存储超长文本)[^3] 4. **元空间/Metaspace溢出** - 动态生成大量类(如反射、CGLIB代理) - JVM参数`-XX:MaxMetaspaceSize`设置过小 5. **线程栈溢出** - 线程数量过多(`-Xss`设置过大导致总栈内存超出限制) #### 二、解决方案 **1. JVM参数调优** ```shell # 设置堆内存(生产环境建议4G起步) java -Xms4g -Xmx4g -XX:+HeapDumpOnOutOfMemoryError -jar app.jar ``` - `-XX:+HeapDumpOnOutOfMemoryError`:生成堆转储文件用于分析[^5] - `-XX:MaxMetaspaceSize=256m`:控制元空间上限 **2. 代码优化** - 及时释放资源(使用`try-with-resources`语法) ```java try (Connection conn = dataSource.getConnection(); PreparedStatement ps = conn.prepareStatement(sql)) { // 操作逻辑 } ``` - 避免静态集合滥用(使用WeakHashMap或定期清理) - 分页处理大数据(如流式读取文件) **3. 内存分析工具** - **MAT(Memory Analyzer Tool)**:分析堆转储文件定位泄漏点 - **VisualVM**:实时监控堆/线程/metaspace使用情况 - **jstat**:命令行查看GC统计信息 **4. 架构层面优化** - 引入分布式缓存(Redis/Memcached)替代本地缓存 - 使用内存池技术管理大对象(如ByteBuffer.allocateDirect) #### 三、典型错误场景 | 错误类型 | 表现特征 | 解决方案 | |---------|---------|---------| | `java.lang.OutOfMemoryError: Java heap space` | 堆内存不足 | 增大`-Xmx` + 检查对象生命周期 | | `java.lang.OutOfMemoryError: Metaspace` | 类元数据溢出 | 调整`MaxMetaspaceSize` + 检查类加载器 | | `java.lang.OutOfMemoryError: Requested array size exceeds VM limit` | 数组过大 | 分块处理数据 | | `java.lang.OutOfMemoryError: unable to create new native thread` | 线程数过多 | 减少线程数 + 调整`-Xss` | [^1]: 需通过代码审查确保资源释放 [^4]: JVM参数需根据服务器物理内存合理设置 : 阿里推荐使用HeapDump参数快速定位问题
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值