美文网首页Java
垃圾回收算法(5)-标记整理算法

垃圾回收算法(5)-标记整理算法

作者: 一觉睡到丶小时候 | 来源:发表于2020-07-10 10:31 被阅读0次

前言

标记清除算法的确可以应用在老年代中,但是该算法不仅执行效率低下,而且在执行完内存回收后会产生内存碎片。所以JVM的设计者在此基础上做了改进,标记压缩法(也称标记整理法)由此诞生。

算法原理

当成功标记出内存中的垃圾对象之后,标记压缩法会将所有的存活对象都移动到一个规整且连续的内存空间中,然后执行Full GC(老年代的垃圾回收,或者被称为Major GC)回收无用对象所占用的内存空间。当成功压缩后,已用和未用的内存都各自一遍,彼此之间维系着一个记录下一次分配起始点的标记指针,当为新对象分配内存时,则可以用指针碰撞(Bump the Pointer)技术修改指针的偏移量将新对象分配在第一个空闲内存位置上。

image

分代概念

为年轻代选择的垃圾回收算法通常是以速度优先,因为年轻代中所存储的瞬时对象声明周期非常短,可以有针对性的使用复制算法。但老年代通常使用更节省内存的回收算法,因为老年代中所存储的对象生命周期都非常长,并且老年代占据了大部分的堆空间,老年代的Full GC不会像年轻代的Minor GC一样频繁,但在FUll GC过程中会耗费很长的时间,标记整理法是不错的选择。

个人博客
腾讯云社区
掘金
CSDN
公众号:

wx.jpg

相关文章

  • 垃圾回收-GC

    1. 垃圾回收算法 垃圾回收算法包括引用计数算法、标记整理、标记复制、标记清除。 1). 引用计数算法 引用计数算...

  • JVM系列(四):浅谈常用四种垃圾回收算法总结!

    常用四种垃圾回收算法 常用的垃圾回收算法有四种:标记-清除算法、复制算法、标记-整理算法、分代收集算法。 1.标记...

  • 垃圾回收算法有几种类型? 他们对应的优缺点又是什么?

    常见的垃圾回收算法有: 标记-清除算法、复制算法、标记-整理算法、分代收集算法 标记-清除算法 标记—清除算法包括...

  • JVM第四天-垃圾收集器

    一、垃圾收集器概述 垃圾收集器是垃圾回收算法(标记-清除算法、复制算法、标记-整理算法、火车算法)的具体实现,不同...

  • Java GC 的那些事(下)

    收集算法 垃圾收集算法主要有:标记-清除、复制和标记-整理。 1、标记-清除算法 对待回收的对象进行标记。 算法缺...

  • JVM读书笔记-垃圾回收算法-06

    垃圾回收算法一共分为四种 标记-清除算法、复制算法、标记-整理算法、分代收集算法 标记-清除算法标记清除算法是最开...

  • 再回首CMS垃圾回收

    前言 之前学习JVM垃圾回收时,主要是过了一遍垃圾收集算法,比如复制算法,标记-清除算法,标记-整理算法,在此基础...

  • GC原理,有哪几种GC方式?

    标记-清除 算法 引用计数法 复制算法 标记-压缩 算法 分代垃圾回收 增量式垃圾回收算法 RC Immix 算法

  • 垃圾回收算法、回收机制与总结 ---JVM

    垃圾回收算法、回收机制与总结 ---JVM 一、垃圾回收算法 1.标记清除 标记--清除算法将垃圾回收分为两个阶段...

  • GC-垃圾收集器

      垃圾回收算法: 引用计数法 复制-拷贝算法 标记-清除法 标记-整理法   主要垃圾收集器: Serial(串...

网友评论

    本文标题:垃圾回收算法(5)-标记整理算法

    本文链接:https://www.haomeiwen.com/subject/txmpcktx.html