关于遇到的JVM内存的相关问题

本文通过分析处理大文本文件时遇到的内存溢出问题,探讨了Java中的内存管理原理及优化方法。文中还介绍了如何避免内存泄漏,并给出了几种常见的内存泄漏类型。

这几天操作的都是一些很大的文本文件,所以总是出现out of memory,特别是用bufferedreader时,由于要存几百MB的文本,所以总会报异常。
今天运行别人的代码,报了java.lang.OutOfMemoryError: Java heap space ,很明显是内存溢出,网上说是“在JVM中如果98%的时间是用于GC且可用的 Heap size 不足2%的时候将抛出此异常信息。”虽然网上给的大部分意见是调大JVM内存,但是对于平常的不算大的项目来说,最关键的还是检查一下代码,有没有在while里面创建对象,有没有重复的引用了资源。但毕竟是别人的代码,我感觉是在那么长的一个while里面创建了中文包对象,可是还是没有找到。

最近也看了一些JVM的知识,主要是不小心使用了-XX:+PrintGC指令打开了GC的console,相关指令的集合link:http://www.cnblogs.com/redcreen/archive/2011/05/04/2037057.html。另外像System.gc()这种东西看了很多相关内容还是不是很清楚有什么必要,有点强迫症的感觉。

顺便引用一下网上的一些关于内存泄露和内存溢出的知识:

内存溢出 out of memory,是指程序在申请内存时,没有足够的内存空间供其使用,出现out of memory;比如申请了一个integer,但给它存了long才能存下的数,那就是内存溢出。
内存泄露 memory leak,是指程序在申请内存后,无法释放已申请的内存空间,一次内存泄露危害可以忽略,但内存泄露堆积后果很严重,无论多少内存,迟早会被占光。
1. 常发性内存泄漏。发生内存泄漏的代码会被多次执行到,每次被执行的时候都会导致一块内存泄漏。
2. 偶发性内存泄漏。发生内存泄漏的代码只有在某些特定环境或操作过程下才会发生。常发性和偶发性是相对的。对于特定的环境,偶发性的也许就变成了常发性的。所以测试环境和测试方法对检测内存泄漏至关重要。
3. 一次性内存泄漏。发生内存泄漏的代码只会被执行一次,或者由于算法上的缺陷,导致总会有一块仅且一块内存发生泄漏。比如,在类的构造函数中分配内存,在析构函数中却没有释放该内存,所以内存泄漏只会发生一次。
4. 隐式内存泄漏。程序在运行过程中不停的分配内存,但是直到结束的时候才释放内存。严格的说这里并没有发生内存泄漏,因为最终程序释放了所有申请的内存。但是对于一个服务器程序,需要运行几天,几周甚至几个月,不及时释放内存也可能导致最终耗尽系统的所有内存。所以,我们称这类内存泄漏为隐式内存泄漏。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值