java垃圾回收学习
经过一个晚上的努力终于完成了一个文件替换指定字符串的程序,但是由于我要替换的全站程序html文件太多,
所以eclipse下边老是在一个目录结束后报出java.lang.OutOfMemoryError: Java heap space的异常,然后就崩溃了。
我一想肯定是频繁操作造成来不及回收,
于是在每个循环之后加上一个Thread.sleep(1000),
发现还是到那个目录下就死掉,于是把1000改成5000,还是到那里死掉,
我想可能不是来不及回收这么简单,或许sun 的JVM里边刚好对于这种情况不释放也有可能。
接着我又把启动的参数添上一个 -Xmx256M,这回就可以了。
还有:Java堆的管理—垃圾回收提到一下几点,很不错,或许可以作为写程序时候的准则:
(1)不要试图去假定垃圾收集发生的时间,这一切都是未知的。
比如,方法中的一个临时对象在方法调用完毕后就变成了无用对象,这个时候它的内存就可以被释放。
(2)Java中提供了一些和垃圾收集打交道的类,
而且提供了一种强行执行垃圾收集的方法--调用System.gc(),
但这同样是个不确定的方法。Java 中并不保证每次调用该方法就一定能够启动垃圾收集,
它只不过会向JVM发出这样一个申请,到底是否真正执行垃圾收集,一切都是个未知数。
(3)挑选适合自己的垃圾收集器。一般来说,如果系统没有特殊和苛刻的性能要求,
可以采用JVM的缺省选项。否则可以考虑使用有针对性的垃圾收集器,
比如增量收集器就比较适合实时性要求较高的系统之中。
系统具有较高的配置,有比较多的闲置资源,可以考虑使用并行标记/清除收集器。
(4)关键的也是难把握的问题是内存泄漏。
良好的编程习惯和严谨的编程态度永远是最重要的,不要让自己的一个小错误导致内存出现大漏洞。
(5)尽早释放无用对象的引用。
大多数程序员在使用临时变量的时候,
都是让引用变量在退出活动域(scope)后,自动设置为null,
暗示垃圾收集器来收集该对象,还必须注意该引用的对象是否被监听,如果有,则要去掉监听器,然后再赋空值。
就是说,对于频繁申请内存和释放内存的操作,还是自己控制一下比较好,
但是System.gc()的方法不一定适用,最好使用finallize强制执行或者写自己的finallize方法。
最新文章
- NET基础(3):is 和 as 操作符
- 简单的mysql封装类
- jquery radio的取值 radio的选中 radio的重置
- 【BZOJ 1022】 [SHOI2008]小约翰的游戏John
- 在oc代码中使用swift第三方框架
- zepto笔记
- MySQL innotop实时监测工具
- zoj 1067
- [有用命令]Linux 用户,用户组
- HttpServletResponse,HttpServletRequest详解
- struts 开发流程
- 【webpack学习笔记】a05-模块热替换
- Java引用类型传递整理
- mysql在增加列前进行判断该列是否存在
- h5中input的request属性提示文字字段
- 团队作业——Alpha冲刺 11/12
- Linux 之 tar和nc传文件
- Android Studio - 安卓开发工具 打开后报错集合、修复指南
- C语言实现<;读取>;和<;写入>; *.ini文件(转)
- spring-boot + mybatis +pagehelper 使用分页
热门文章
- Nginx做代理
- Vue - 让水平滚动条(scroll bar)固定在浏览器的底部
- django urls.py 中的name 使用方法
- AI人工智能之基于OpenCV+face_recognition实现人脸识别
- opencv:像素统计信息
- C:产生随机数
- 201771010135 杨蓉庆《面对对象程序设计(java)》第十二周学习总结
- ES6-形参默认值
- STM32F030 启用内部晶振并配置系统时钟为48M
- Codeforces Round #602 (Div. 2, based on Technocup 2020 Elimination Round 3) - D2. Optimal Subsequences (Hard Version)(主席树)