几种垃圾回收算法

垃圾回收GC的全拼是 Garbage Collection 其在维基百科的定义是: 在计算机科学中,垃圾回收(英语:Garbage Collection,缩写为GC)是一种自动的内存管理机制。当一个电脑上的动态内存不再需要时,就应该予以释放,以让出内存,这种内存资源管理,称为垃圾回收(garbage collection)

垃圾回收算法有多种,先看看几个评价垃圾回收算法性能的几个方面,再具体看看各种算法的优缺点

  • 吞吐量 throughput
  • 最大暂停时间
  • 堆使用效率
  • 访问的局部性

一、 标记-清除算法 Mark-Sweep GC

如字面意思 mark-sweep 分为两个阶段:

  1. 标记阶段:从根集合出发,将所有活动对象及其子对象打上标记
  2. 清除阶段:遍历堆,将非活动对象(未打上标记)的连接到空闲链表上


    标记-清除算法

优点

实现简单, 容易和其他算法组合

缺点

  • 碎片化, 会导致无数小分块散落在堆的各处
  • 分配速度不理想,每次分配都需要遍历空闲列表找到足够大的分块
  • 与写时复制技术不兼容,因为每次都会在活动对象上打上标记

二、标记-压缩 Mark-Compact

和“标记-清除”相似,不过在标记阶段后它将所有活动对象紧密的排在堆的一侧(压缩),消除了内存碎片, 不过压缩是需要花费计算成本的。如下图过程,标记后需要定位各个活动对象的新内存地址,然后再移动对象,总共搜索了3次堆。


标记-压缩算法

优点

有效利用了堆,不会出现内存碎片 也不会像复制算法那样只能利用堆的一部分

缺点

压缩过程的开销,需要多次搜索堆

三、引用计数 Reference Counting

引用计数,就是记录每个对象被引用的次数,每次新建对象、赋值引用和删除引用的同时更新计数器,如果计数器值为0则直接回收内存。 很明显,引用计数最大的优势是暂停时间短

优点

  • 可即刻回收垃圾
  • 最大暂停时间短
  • 没有必要沿指针查找, 不要和标记-清除算法一样沿着根集合开始查找

缺点

  • 计数器的增减处理繁重
  • 计数器需要占用很多位
  • 实现繁琐复杂, 每个赋值操作都得替换成引用更新操作
  • 循环引用无法回收

四、 GC 复制算法

将堆分为两个大小相同的空间 From 和 To, 利用 From 空间进行分配,当 From 空间满的时候,GC将其中的活动对象复制到 To 空间,之后将两个空间互换即完成GC。


GC复制算法

优点

  • 优秀的吞吐量, 只需要关心活动对象
  • 可实现高速分配; 因为分块是连续的,不需要使用空闲链表
  • 不会发生碎片化
  • 与缓存兼容

缺点

  • 堆使用率低
  • 与保守式GC不兼容
  • 递归调用函数, 复制子对象需要递归调用复制函数 消耗栈

五、 保守式GC

根空间有以下几种:

  • 寄存器
  • 调用栈
  • 全局变量空间

但这些都是不明确的根, 因为调用栈里边的调用帧(call frame) 既有指针也有非指针(值类型)

保守式GC检查不明确根的基本项目:

  1. 是不是被正确对齐的值?(在32位cpu的情况下,为4的倍数)
  2. 是不是指针堆内?
  3. 是不是指着对象的开头?

有种情况是,非指正和堆里的对象地址一样;这时保守式GC “把可以的东西看做指针,稳妥处理”

保守式GC优点:GC不依赖于语言处理程序

缺点:

  • 识别指针和非指针需要成本
  • 错误识别指针会压迫堆; 可能错将非指针当做指针,然后将其作为内存地址使得对应堆中的死对象当做活对象
  • 能够使用的gc算法有限; 不能使用复制算法这类移动对象的gc算法
准确式GC

需要依赖 “语言处理程序的支援”,能基于能精确识别指针和非指针的“正确根”来执行gc

六、分代回收

出发点:大部分对象生成后马上就变成垃圾,很少有对象能活的很久

  • 新生代 = 生成空间 + 2 * 幸存区 复制算法
  • 老年代 标记-清除算法

对象在生成空间创建,当生成空间满之后进行 minor gc,将活动对象复制到第一个幸存区,并增加其“年龄” age,当这个幸存区满之后再将此次生成空间和这个幸存区的活动对象复制到另一个幸存区,如此反复,当活动对象的 age 达到一定次数后将其移动到老年代; 当老年代满的时候就用标记-清除或标记-压缩算法进行major gc

吞吐量得到改善, 分代垃圾回收花费的时间是GC复制算法的四分之一;但是如果部分程序新生成对象存活很久的话分代回收会适得其反

七、增量式GC

本来gc只是默默的在幕后回收资源的,但是如果gc任务繁重则会长时间暂停应用程序的执行, 增量式gc就是一种逐渐推进垃圾回收来控制mutator最大暂停时间的方法

三色标记算法

  • 白色: 还未搜索过的对象
  • 灰色: 正在搜索的对象
  • 黑色: 搜索完成的对象

根查找阶段: 对能直接从根引用的对象打上标记,堆放到标记栈里(白色 涂成 灰色)

标记阶段: 从标记栈中取出对象,将其子对象涂成灰色;这个阶段不是一下子处理所有的灰色对象,而只是处理一定个数,然后暂停gc

清除阶段: 将没被标记的白色对象连接到空闲链表,并重置已标记的对象标记位

优点: 缩短最大暂停时间
缺点: 降低了吞吐量

resources:
维基百科 - 垃圾回收
深入理解java垃圾回收机制
聊聊JVM的年轻代

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容