垃圾对象的判断
引用计数法
对象中添加一个引用计数器,每当有地方引用它,计数器 +1 。当引用失效的时候,计数器 -1。
这种方法实现简单效率高,但是主流虚拟机没有用这种方法。因为无法解决循环依赖的问题。如果存在两个对象相互引用,那么两个对象的计数器永远不为0,永远无法被回收。
可达性分析法
将GC Roots 对象作为起点,从起点开始向下搜索引用的对象,将找到的对象标记为非垃圾对象,其余都是垃圾对象。
GC Roots
线程的本地变量,静态变量,本地方法栈的变量等等
对象在垃圾回收之前的自救
即使在可达性分析法中,不可达的对象也不一定是非被回收不可。
垃圾回收的时候会回收未被标记的,且未重写finalize()方法或者finalize()方法已经执行过的对象。
所以我们可以在对象内部重写finalize()方法去拯救一次对象,只需要重新与引用链上的任何一个对象建立起关联关系即可。
JVM垃圾回收算法
复制算法
将分配的内存空间一分为二,实际可用的内存空间其实就只有一半。