一、找到“垃圾”——死亡对象
方法:
1、引用计数算法,记录每个对象的引用情况;
2、可达性分析法,从“GC Roots”对象作为起点,然后向下搜索,搜索走过的路径称为“引用链”,如果一个对象没有任何引用链,那么就表示这个对象不可达,已没有在使用,可以被回收;
二、垃圾收集算法
1、标记清除法:标记出不用的对象地址,然后再逐个清除掉;
缺点:会导致内存不连续;
2、复制清除法:将内存分成两个区域,开始垃圾收集时,将还在使用的对象复制到空白区域,然后清楚掉原区域,这样循环使用;
缺点:需要较大的内存空间;
3、标记整理法:类似“标记清除法”,只是在清理完后,再将在用的内存块做压缩整理,使其变的连续;
缺点:无
4、分代收集算法:该算法是将堆内存分成:新生代(Eden区、Survivor From区、Survivor To区)、老年代;垃圾收集时对新生代使用:复制清除算法,对老年代使用:标记清楚算法;
缺点:无
2402

被折叠的 条评论
为什么被折叠?



