gc 的几种算法:
引用计数法,通过对对象的引用计数来判断是否可以被回收,实际中不会使用
根搜索算法,根搜索就涉及到gc root ,哪些可以作为根呢?在java语言中,可以作为根的对象有:
1 .虚拟机栈中的引用的对象
2.方法区中的类静态属性引用的对象
3.方法区中常量引用的对象(标记为 final 的对象)
4.本地方法栈中JNI引用的对象
在确定那些对象可以回收后,如何进行回收,使用标记-清除算法。分为两个步骤
1.标记
2.清除
缺点:效率低,需要遍历全堆对象,清理后空闲内存不连续。
真正的GC 算法: 复制算法,最大的问题是空间浪费,这种适用于新生代。标记/整理算法适用于老年代。
全局暂停:stop-the-world, native代码可以继续执行,但不能和JVM 交互,问题:全局暂停可能会引起主备切换,导致系统不一致问题。
HotSpot 虚拟机 Eden 和survivor permanent
CMS 收集器(并发标记清除):停顿时间比较短,需要多次清除,容易产生碎片
5843

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



