1、概述
垃圾回收(Garbage Collection,GC),顾名思义就是释放垃圾占用的空间,防止内存泄露。有效的使用可以使用的内存,对内存堆中已经死亡的或者长时间没有使用的对象进行清除和回收。
2、判断垃圾算法
在分析判断垃圾算法之前, 先熟悉以下Java虚拟机运行时数据区域。如下图所示:
2.1 引用计数法
用对象计数器是否为0来判断对象是否可被回收。
给每个对象添加一个计数器,当有地方引用该对象时计数器加1,当引用失效时计数器减1。
缺点:无法解决循环引用的问题。
先创建一个字符串,String m = new String("jack");
,这时候 “jack” 有一个引用,就是m。然后将m设置为null,这时候 “jack” 的引用次数就等于 0 了,在引用计数算法中,意味着这块内容就需要被回收了。
引用计数算法是将垃圾回收分摊到整个应用程序的运行当中了,而不是在进行垃圾收集时,要挂起整个应用的运行,直到对堆中所有对象的处理都结束。因此,采用引用计数的垃圾收集不属于严格意义上的Stop-The-World的垃圾收集机制。
看似很美好,但我们知道JVM的垃圾回收就是Stop-The-World的,那是什么原因导致我们最终放弃了引用计数算法呢?看下面的例子。
public class ReferenceCountingGC {
public Object instance;
private String name;
public ReferenceCountingGC(String name) {
this.name = name;
}
public static void testGC(){
ReferenceCountingGC a = new ReferenceCountingGC("objA");
ReferenceCountingGC b = new ReferenceCountingGC("objB");
a.instance = b;
b.