目录
2.2 可达性分析(Reachability Analysis):
1、需要GC的内存区域
jvm
中,程序计数器、虚拟机栈、本地方法栈都是随线程而生随线程而灭,栈帧随着方法的进入和退出做入栈和出栈操作,实现了自动的内存清理,因此,我们的内存垃圾回收主要集中于 java
堆
和
方法区中,在程序运行期间,这部分内存的分配和使用都是动态的。
2、判断GC对象是否存活
判断一个对象是否存活常用的有两种办法:引用计数和可达分析:
2.1 引用计数:
堆中的对象每被引用一次,则计数器加1,每减少一个引用就减1,当对象的引用计数器为0时可以被当作垃圾收集。
优点:算法执行效率高,实现起来简单。
缺点:无法检测出对象之间的循环引用现象。如两个对象互相引用时,他们的引用计数永远不可能为0。
Java
没有选择使用引用计数算法管理内存。
2.2 可达性分析(Reachability Analysis):
可达性分析算法是把所有的引用关系看作一张图,从一个结点根对象(GC ROOT)开始,寻找对应的引用结点。找到这个结点以后,继续寻找这个结点的引用结点。当所有的引用结点寻找完毕之后,剩余的结点则被认为是没有被引用到的结点,即可以当作jvm垃圾回收的目标。
Java中可作为GC Root的对象有:
1.虚拟机栈中引用的对象。
2.本地方法栈引用的对象。
2.方法区中静态属性引用的对象。
3.方法区中常量引用的对象。