GC--原理和常见回收算法

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/gzl0524/article/details/79614861

一.   原理

GC是垃圾收集的意思(Garbage Collection),内存处理是编程人员容易出现问题的地方,忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃,Java提供的GC功能可以自动监测对象是否超过作用域从而达到自动回收内存的目的,Java语言没有提供释放已分配内存的显示操作方法。

简而言之,GC是将java的无用的堆对象进行清理,释放内存,以免发生内存泄露

二 .   常见回收算法

1、标记-清除算法:

标记阶段:先通过根节点,标记所有从根节点开始的可达对象。因此,未被标记的对象就是未被引用的垃圾对象;

清除阶段:清除所有未被标记的对象。

2、复制算法:(新生代的GC)

将原有的内存空间分为两块,每次只使用其中一块,在垃圾回收时,将正在使用的内存中的存活对象复制到未使用的内存块中,然后清除正在使用的内存块中的所有对象。

3、标记-整理算法:(老年代的GC)

标记阶段:先通过根节点,标记所有从根节点开始的可达对象。因此,未被标记的对象就是未被引用的垃圾对象

整理阶段:将将所有的存活对象压缩到内存的一端;之后,清理边界外所有的空间

4、分代收集算法:

存活率低:少量对象存活,适合复制算法:在新生代中,每次GC时都发现有大批对象死去,只有少量存活(新生代中98%的对象都是“朝生夕死”),那就选用复制算法,只需要付出少量存活对象的复制成本就可以完成GC。

存活率高:大量对象存活,适合用标记-清理/标记-整理:在老年代中,因为对象存活率高、没有额外空间对他进行分配担保,就必须使用“标记-清理”/“标记-整理”算法进行GC。

猜你喜欢

转载自blog.csdn.net/gzl0524/article/details/79614861