java虚拟机(2)--垃圾回收

判定对象是否存活:
可达性分析算法:这个算法的基本思路就是通过一系列的称为GC Roots的对象作为起始点,从这些节点开始向下搜索,搜索所走过的路径称为引用链,当一个对象到GC Roots没有任何引用链相连时,则证明此对象是不可用的。
可作为GC Roots的对象包括:
虚拟机栈中引用的对象,方法区中类静态属性引用的对象,方法区中常量引用的对象,本地方法栈中JNI引用的对象。
垃圾收集算法:
标记-清除算法:首先标记出所有需要回收的对象,在标记完成后统一回收所有被标记的对象。效率比较低, 并且会产生大量不连续的内存碎片。
复制算法:将内存分为一块较大的Eden空间,和两块较小的Survivor空间,每次使用Eden和其中一块Survivor。当回收时,将Eden和Survivor中还存活的对象一次性地复制到另一块Survivor空间上,最后清除掉Eden和刚才用过的Survivor空间。当Survivor空间不够用的时候,需要依赖其他内存(这里指老年代)进行分配担保。
标记整理算法:标记出所有的需要回收的对象后,将所有存活的对象都向一端移动,然后清除掉端边界以外的内存。

猜你喜欢

转载自blog.csdn.net/lalalahaitang/article/details/81176908