JVM垃圾收集器

JVM的垃圾收集器基于分代收集理论,包括Serial、Parallel Scavenge、ParNew和CMS等。每种收集器都有不同的特点和适用场景,如Serial和Serial Old适合简单场景,Parallel Scavenge关注CPU吞吐量,CMS则追求最短停顿时间。标记-复制、标记-清除和标记-整理等算法各有优缺点,CMS使用三色标记法解决并发标记的浮动垃圾和漏标问题。
摘要由CSDN通过智能技术生成

垃圾收集算法

分代收集理论

目前 jvm 的垃圾收集器都采用分代收集理论,根据对象的存活周期分为老年代和年轻代,这样就可以根据每个年代的特点采用的合适的垃圾收集算法。

标记-复制算法

复制算法将内存分为大小相同的两块,每次只使用其中一块,当这一块的内存用完时,就将这块区域内还存活的对象复制到另外一块区域去,再把这一块的区域清空。
优点:效率高。
缺点:只能使用一半的内存,利用率不高。
在这里插入图片描述

标记-清除算法

标记-清除分为两个阶段:标志清除。标记还存活的对象,回收未被标记的对象,反之亦可。
优点:
相较于复制算法内存利用率较高。
缺点:

  1. 会产生大量不连续的内存碎片。
  2. 如果需要标记的对象较多,那么效率较低。
    在这里插入图片描述
标记-整理算法

标记阶段于 标记-清除算法 一样,区别在于后续步骤不是回收对象,而是让还存活的对象往内存的一端移动,然后清理掉边界以外的内存。
在这里插入图片描述

对于年轻代,每次收集都会有大量的对象死去,适合使用复制算法,仅需要付出少量的复制代价就能完成垃圾收集。
对于老年代,大多数对象都是长时间存活的,且没有空间进行分配担保,必须采用 标记-清除 或者 标记-整理算法。
标记-清除 或者 标记-整理算法会比复制算法慢10倍以上。


垃圾收集器

1. Serial
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值