您的位置:首页 > 编程语言 > Java开发

系统整理java垃圾回收

2016-12-07 19:34 176 查看
一种垃圾回收算法一般要做2件基本的事情:(1)发现无用信息对象;(2)回收被无用对象占用的内存空间,使该空间可被程序再次使用。

根集的概念

引用计数器法 ,引用+1,退出作用域-1,为0满足回收

tracing算法,标记和清除(mark-and-sweep)垃圾收集器

compacting算法

copying算法

generation算法(年轻带,年老带)

逐渐进化

finalize()方法

释放不是new方法开辟出来的内存空间

触发主GC(Garbage Collector)的条件

1.程序空闲时

2.内存不足时

减少gc开销

1.不要显式调用System.gc()

2.尽量减少临时对象的使用(此处有疑问,记得之前看过方法内要尽量用新的变量,记不清了,以后研究)

3对象不使用时显示置为null(谁会在每个对象用完后都==null一次呢,代码不好看了啊)

4.使用stringbuffer 而不是string

5.基本类型int 不使用integer(占内存多)

6.少用静态变量(有些地方还是用静态方便啊)

7.分散对象创建和删除的时间(个人理解就是在程序中,使用对象的时候再创建,不要 为了美观,把所有对象都在一起创建)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: