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