怎么判断是否垃圾?
枚举根节点,做可达性分析
根节点:类加载器,Thread,局部变量表,static成员,常量,本地方法栈的变量等
采用什么算法回收垃圾
1.标记清除算法
缺点:效率不高,产生碎片,导致提前GC
2.复制算法
定义:2块区域,当发生GC时,将存活的复制到另一块,GC完成后再将存活的还回来
优点:简单高效
缺点:利用率低,最高只能使用50%内存
3.标记整理
定义:通过可达性分析后标记出需要清理的无用内存,并不直接清理,而是存活的对象向另一端平移,后对边界外的内存进行垃圾回收
优点:避免了内存碎片化
缺点:整理内存比较耗时
怎么选择?
jvm采用分代收集算法
yong区因为有着朝生夕死的特点,所以采用复制算法
old区因为对象存活时间比较长,所以采用的时标记整理算法
JVM垃圾回收判断、算法及选择
博客围绕JVM垃圾回收展开,介绍了判断垃圾的方法,即枚举根节点做可达性分析,根节点包括类加载器、Thread等。还阐述了三种垃圾回收算法,标记清除、复制、标记整理,分析其优缺点。最后说明JVM采用分代收集算法,yong区用复制算法,old区用标记整理算法。

1382

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



