系统整理java垃圾回收

一种垃圾回收算法一般要做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.分散对象创建和删除的时间(个人理解就是在程序中,使用对象的时候再创建,不要 为了美观,把所有对象都在一起创建)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值