⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 java+

📁 世界知名IT公司的JAVA面试题
💻
字号:
经过一个晚上的努力终于完成了一个文件替换指定字符串的程序,
但是由于我要替换的全站程序html文件太多,
所以eclipse下边老是在一个目录结束后报出java.lang.OutOfMemoryError: Java heap space的异常,然后就崩溃了。
我一想肯定是频繁操作造成来不及回收,
于是在每个循环之后加上一个Thread.sleep(1000),
发现还是到那个目录下就死掉,于是把1000改成5000,还是到那里死掉,
我想可能不是来不及回收这么简单,或许sun 的JVM里边刚好对于这种情况不释放也有可能。
接着我又把启动的参数添上一个 -Xmx256M,这回就可以了。

想一想,还是对于垃圾回收的原理不太了解,就在网上查了一下,发现了几篇不错的文章。

http://java.ccidnet.com/art/3539/20060314/476073_1.html
http://www.pconline.com.cn/pcedu/empolder/gj/java/0509/701281.html


还有:Java堆的管理—垃圾回收提到一下几点,很不错,或许可以作为写程序时候的准则:
(1)不要试图去假定垃圾收集发生的时间,这一切都是未知的。
	比如,方法中的一个临时对象在方法调用完毕后就变成了无用对象,这个时候它的内存就可以被释放。 

(2)Java中提供了一些和垃圾收集打交道的类,
	而且提供了一种强行执行垃圾收集的方法--调用System.gc(),
	但这同样是个不确定的方法。Java 中并不保证每次调用该方法就一定能够启动垃圾收集,
	它只不过会向JVM发出这样一个申请,到底是否真正执行垃圾收集,一切都是个未知数。

(3)挑选适合自己的垃圾收集器。一般来说,如果系统没有特殊和苛刻的性能要求,
	可以采用JVM的缺省选项。否则可以考虑使用有针对性的垃圾收集器,
	比如增量收集器就比较适合实时性要求较高的系统之中。
	系统具有较高的配置,有比较多的闲置资源,可以考虑使用并行标记/清除收集器。

(4)关键的也是难把握的问题是内存泄漏。
良好的编程习惯和严谨的编程态度永远是最重要的,不要让自己的一个小错误导致内存出现大漏洞。

(5)尽早释放无用对象的引用。
	大多数程序员在使用临时变量的时候,
	都是让引用变量在退出活动域(scope)后,自动设置为null,
	暗示垃圾收集器来收集该对象,还必须注意该引用的对象是否被监听,如果有,则要去掉监听器,然后再赋空值。

	就是说,对于频繁申请内存和释放内存的操作,还是自己控制一下比较好,
	但是System.gc()的方法不一定适用,最好使用finallize强制执行或者写自己的finallize方法。


⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -