2023/08/13_______JVM(CG)垃圾回收 算法(复制算法,标记清除,标记清除压缩)

本文详细介绍了JVM中的三种GC算法:复制算法(适用于存活度低的对象)、标记清除算法(产生内存碎片但节省空间)和标记压缩算法(内存效率高但可能有时间复杂度问题)。讨论了它们在不同代(年轻代和老年代)的应用及优缺点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JVM GC算法

复制算法

1,每一次GC都会将伊甸(Eden)活的对象移到幸存区中:一旦Eden区被GC后 就会是空

只要有内容就是from区
谁空谁是to区
内存会从 伊甸->幸存区to->幸存from(这个时候to和from交换区域)

在这里插入图片描述

在这里插入图片描述

每一次GC(垃圾回收)以后伊甸园空幸存区to都是空的

好处:没有内存碎片
坏处:浪费一半空间(幸存to区)
复制算法最佳使用场景,对象存活度较低的时候

标记清除算法

在这里插入图片描述

优点:不需要额外的内存空间
缺点:两次扫描浪费时间,会产生内存碎片

标记清除压缩算法

在这里插入图片描述

内存效率:复制算法>标记清除算法>标记压缩算法(时间复杂度问题)
内存整齐度:复制算法=标记压缩算法>标记清除算法
内存利用率:标记压缩算法=标记清除算法>复制算法

年轻代:

  • 存活率低

  • 复制算法
    老年代:

  • 区域大:存活录

  • 标记清除(内存碎片不是太多)+标记压缩混合实现

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值