JVM垃圾收集算法

不善于讲前世今生,由于是自己看,直接就分享干货,用尽量简短的文字,描述清除每个知识点,是我的追求。

1、标记-清除算法
   从算法的名字就能看出,该算法总共有两步。第一步标记,标记需要进行垃圾回收的对象;第二步清除,将能够回收的对象进行清除。
   标记-清除算法都是在新生代垃圾收集器上使用,所以标记-清除算法主要是用来清除新生代的对象。
   标记-清除算法主要有两方面问题:1)效率不高;2)清除过程产生的空间碎片,导致产生不连续的空间,如果有比较大的对象,可能导致垃圾回收的提前执行
2、复制算法
   复制算法是针对标记-清除算法的缺点改造的。原理是将回收的区域分成两块,每次只使用其中的一块,当垃圾回收完之后将还存活的对象复制到另外一块内存中,简单,高效,但是缺点也很明显就是浪费了一半的空间,有点类似用空间换效率的思想。
   实际的算法实现上,根据IBM的专门研究,新生代中的对象98%都是朝生夕死的,所以也并不需要按照1:1的比例来划分内存空间,而是将内存分为一块较大的Eden空间和两块较小的Survivor空间,空间比例是8:1:1,这样每次只有10%的空间被浪费。当然我们并不能保证每次存活下来的对象都不超过内存的10%,,那么超出的部分怎么办?jvm中有一个分配担保机制来保证超出部分的内存可以用其他内存来替代,主要是老年代的内存。

3、标记-整理算法
   标记-整理算法也是针对标记-清除算法的缺点改造的,标记过程和标记-清除算法的过程一样,但是标记完成之后不是立马进行清理释放空间,而是向一方移动,即整理。在全部移动完毕后,进行清理,这样就不会产生空间碎片。另外也不需要复制算法浪费一半空间(而且复制算法会在如果存活对象比较多时,会产生大量的复制操作,降低效率),或者需要担保禁止来应对超出内存10%的情况。

4、分代收集算法
   分代收集算法并不是什么新的思想,我理解就是分治的思想,将jvm根据对象的特点将内存分为几块,一般分为新生代和老年代,新生代朝生夕死,可以用复制算法,只需要付出少量的复制成本即可,老年代因为存活率高,也没有分配担保就使用标记-清除或者标记-整理算法来进行回收。

ps:由于水平有限,难免出现理解错误的地方,欢迎各位大佬留言沟通指导,不胜感激。

你可能感兴趣的:(JVM)