引用计数法:引用计数法的实现很简单,对于一个对象A,只要有任何一个对象引用了A,则A的引用计数器就加1,当引用失效时,引用计数器就减一。只要对象A的引用计数器的值为0,则对象A就不能再被使用。
标记-清除算法:标记-清除算法将垃圾回收分为两个阶段:标记阶段和清除阶段。一种可行的实现是,在标记阶段,首先通过根节点,标记所有从根节点开始的可达对象。因此,未被标记的对象就是未被引用的垃圾对象。然后,在清除阶段,清除所有未被标记的对象。
复制算法:将原有的内存空间分为两块,每次只使用其中一块,在垃圾回收时,将正在使用的内存中的存活对象复制到未使用的内存块中,之后,清除正在使用的内存块中的所有对象,交换两个内存中的角色,完成垃圾回收。
标记-压缩算法:首先从根节点开始,对所有可达的对象做一次标记,但之后,它并不是简单的清理未标记的对象,而是将所有的存活对象压缩到内存空间的一端。之后,清理边界外所有的空间。
分代:将内存区域根据对象的特点分成不同的内存区域,根据每块区域对象的特征不同使用不同的回收算法,以提高垃圾回收的效率。
可以作为GC中root的对象:
1.被启动类加载的类和创建的对象
2.栈内存中引用的对象
3.方法区中静态和常量引用的对象
4.本地方法中JNI引用的对象
本文深入解析了五种主要的垃圾回收算法:引用计数法、标记-清除算法、复制算法、标记-压缩算法以及分代收集策略。同时,介绍了哪些对象可以作为GC中的root对象,包括启动类加载的类、栈内存中的引用对象等。
5万+

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



