标记整理和标记压缩算法有什么区别

标记-整理算法(Mark-Compact)和标记-压缩算法(Mark-Sweep-Compact)在垃圾回收中都是基于标记阶段的,但它们在清理和处理对象的存储布局上有明显的区别。

1. 标记-整理算法(Mark-Compact Algorithm)

标记-整理算法 主要分为两个阶段:

  • 标记阶段:首先标记出所有存活的对象。
  • 整理阶段:将所有存活的对象向一端移动,紧凑地排列在一起,清理无效空间并保证内存连续性。
关键特点:
  • 内存连续性:通过将存活的对象压缩到内存的一端,确保剩余的内存是连续的,这有助于避免内存碎片。
  • 对象移动:整理阶段会移动对象的位置,因此需要更新对象的引用。
  • 适用于老年代:该算法常用于回收老年代,因为老年代的对象存活时间较长,整理有助于减少内存碎片,避免频繁的 GC。
优点:
  • 由于内存空间被整理成连续的空间,后续的内存分配更加高效。
  • 减少内存碎片,适合长时间运行的应用。
缺点:
  • 移动存活对象时&
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蘋天纬地

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值