Mark Compact GC (Part one: Lisp2)

目录

  • 什么是GC 标记-压缩算法

    • Lisp2 算法的对象
    • 概要
  • 步骤
    • 步骤一:设定forwarding指针
    • 步骤二:更新指针
    • 步骤三:移动对象
  • 优缺点

什么是GC 标记-压缩算法

需要对标记清除和GC复制算法有一定了解

GC标记-压缩算法是由标记阶段压缩阶段构成。

标记阶段和标记清除的标记阶段完全一样。之后我们要通过搜索数次堆来进行压缩。

Lisp2 算法的对象

Donald E.Knuth

对象结构如图示:

Lisp2 算法在对象头中为forwarding指针留出空间,forwarding指针表示对象的目标地点。(设定forwarding时,还不存在移动完毕的对象)

概要

假设我们在下图所示的状态下执行GC

标记完后状态如下(过程与标记清除算法相同)

压缩完后的状态如下(可以看到,他们现在的位置是挨着的。)

这种算法并不会对对象的顺序产生影响,知识缩小了他们之间的空隙,让他们聚集在堆的一端。

步骤

压缩阶段代码

compaction_phase(){
    set_forwarding_ptr() // 设置forwarding指针
    adjust_ptr() // 更新指针
    move_obj() // 移动对象
}

步骤一:设定forwarding指针

首先程序会搜索整个堆,给活动的对象设定forwarding指针。初始状态下forwarding是NULL。

set_fowarding_ptr(){
    scan = new_address = $heap_start
    while(scan < $heap_end)
        if(scan.mark = TRUE)
            scan.forwarding = new_address
            new_address += scan.size
        scan += scan.size
}
  • scan 用来搜索堆中的指针,new_address指向目标地点的指针。
  • 一旦scan找到活动对象,forwarding指针就要被更新。按着new_address对象的长度移动。
  • 如下图示:

步骤二:更新指针

adjust_ptr(){
    for(r :$roots)  // 更新根对象的指针
        *r = (*r).forwarding

    scan = $heap_start
    while(scan < $heap_end)
        if(scan.mark == TRUE)
            for(child :children(scan)) // 通过scan 更新其他对象指针
                *child = (*child).forwarding
        scan += scan.size
}
  • 首先更新根的指针
  • 然后重写所有活动对象的指针(对堆进行第二次的搜索)

步骤三:移动对象

搜索整个堆(第三次搜索),再将对象移动到forwarding指针的引用处。

move_obj(){
   scan = $free = $heap_start
   while(scan < $heap_end)
    if(scan.mark == TRUE) // 判断是否是活动对象
        new_address = scan.forwarding  // 获取对象要移动的地点
        copy_data(new_address, scan, scan.size) // 复制对象(移动对象)
        new_address.forwarding = NULL // 将forwarding改为NULL
        new_address.mark = FALSE // mark改为FALSE
        $free += new_address.size // 指针后移
        scan += scan.size // 指针后移
}

  • 算法不会对对象本身的顺序进行改变,只会把对象集中在堆的一端。
  • 算法没有去删除对象,知识吧对象的mark设置为FALSE
  • 之后把forwarding改为NULL,标志位改为FALSE,将$free移动obj.size个长度。

优缺点

优点:可有效利用堆

使用整个堆在进行垃圾回收,没啥说的。任何的算法都是有得有失,用时间换空间。或者用空间换时间。重要的是它在这里

适不适用。

缺点:压缩花费计算成本

Lisp2 算法中,对堆进行了3次搜索。在搜索时间与堆大小成正相关的状态下,三次搜索花费的时间是很恐怖。也就是说,它的吞吐量要低于其他算法。时间成本至少是标记清除的三倍(当然不包含mutator)

原文地址:https://www.cnblogs.com/Leon-The-Professional/p/9994389.html

时间: 2024-10-10 23:28:29

Mark Compact GC (Part one: Lisp2)的相关文章

Mark Compact GC (Part two :Two-Finger)

目录 Two-Finger算法 前提 概要 步骤一:移动对象 步骤二:更新指针 优缺点 表格算法 概要 步骤一:移动对象群 和 构筑间隙表格 移动对象群 构筑间隙表格 步骤二:更新指针 优缺点 Two-Finger算法 Robert A.Saunders 对堆执行两次搜索 前提 Two-Finger 算法,必须将所有对象整理成大小一致.它没有在对象的头中设立forwarding指针,而是在对象的域中设立forwarding指针即可. 概要 Two-Finger算法由一下两个步骤构造. 移动对象

GC标记-清除算法(Mark Sweep GC)

世界上第一个GC算法,由 JohnMcCarthy 在1960年发布. 标记-清除算法由标记阶段和清除阶段构成. 标记阶段就是把所有的活动对象都做上标记的阶段. 标记阶段就是"遍历对象并标记"的处理过程. 标记阶段经常用到深度优先搜索. 清除阶段就是把那些没有标记的对象,也就是非活动对象回收的阶段. 清除阶段collector会遍历整个堆,回收没有打上标记的对象(即垃圾). 内存的合并操作也是在清除阶段进行的. 分配 分配指将回收的内存空间进行再利用. -> 伪代码实现内存分配

几种垃圾回收GC概述

垃圾回收机制 引用计数回收器(Reference Counting Collector) 原理是在每个对象内部维护一个整数值,叫做这个对象的引用计数,当对象被引用时引用计数加一,当对象不被引用时引用计数减一.当引用计数为 0 时,自动销毁对象. 目前引用计数法主要用在 c++ 标准库的 std::shared_ptr .微软的 COM .Objective-C 和 PHP 中. 计数器表示资源(内存中的对象)的使用次数,当计数器变成零的时候就可以将该资源销毁.在向已有的系统添加垃圾回收器时,开发

HotSpot JVM and GC basics study note

Hotspot JVM and GC basics study note JVM components HotSpot JVM comprises three main components: the class loader, the runtime data areas and the execution engine. Key JVM components There are three key components related to tune performance: the hea

[译]GC专家系列1: 理解Java垃圾回收

原文链接:http://www.cubrid.org/blog/dev-platform/understanding-java-garbage-collection/ 了解Java的垃圾回收(GC)原理能给我们带来什么好处?对于软件工程师来说,满足技术好奇心可算是一个,但重要的是理解GC能帮忙我们更好的编写Java应用程序. 上面是我个人的主观的看法,但我相信熟练掌握GC是成为优秀Java程序员的必备技能.如果你对GC执行过程感兴趣,也许你只是有一定的开发应用的经验:如果你仔细考虑过如何选择合适

Java GC专家系列1:理解Java垃圾回收

了解Java的垃圾回收(GC)原理能给我们带来什么好处?对于软件工程师来说,满足技术好奇心可算是一个,但重要的是理解GC能帮忙我们更好的编写Java应用程序. 上面是我个人的主观的看法,但我相信熟练掌握GC是成为优秀Java程序员的必备技能.如果你对GC执行过程感兴趣,也许你只是有一定的开发应用的经验:如果你仔细考虑过如何选择合适的GC算法,说明你对你所开发的程序有了全面的了解.当然这对一个优秀的程序员来说未必是一个通用的标准,但很少人会反对我关于”理解GC是作为优秀Java程序员的必备技能”的

Java 垃圾回收(GC) 泛读

Java 垃圾回收(GC) 泛读 文章地址:https://segmentfault.com/a/1190000008922319 0. 序言 带着问题去看待 垃圾回收(GC) 会比较好,一般来说主要的疑惑在于这么几点: 为什么需要 GC ? 虚拟机(JVM) 与 垃圾回收(GC) 的关系? GC 的原理有哪些? 哪些 对象容易被 GC ? 等等 带着这些问题往下看: 1. 为什么需要 GC ? GC: 是Garbage Collection 的英文缩略,垃圾收集的意思. 为什么需要 GC?主要

【甘道夫】HBase随机宕机事件处理 &amp; JVM GC回顾

一.引言 本文记录了困扰团队两周的HBase随机宕机事件的解决方案,并回顾了JVM GC调优基础知识,供各位参考. 欢迎转载,请注明出处: http://blog.csdn.net/u010967382/article/details/42394031 二.实验环境 16台虚拟机,每台4G内存,1核CPU,400G硬盘 Ubuntu 14.04 LTS (GNU/Linux 3.13.0-29-generic x86_64) CDH5.2.0套装(包括相应版本的Hadoop,HIVE,Hbase

Understanding .net CLR garbage collection--(踏踏实实学好.Net系列)

引言 内存管理是计算机科学中一个相当复杂而有趣的领域.在计算机诞生的这几十年间,内存的管理的技术不断进步,使系统能够更加有效地利用内存这一计算机必不可少的资源. 一般而言,内存管理可以分为三类:硬件管理(如TLB),操作系统管理(如Buddy System,Paging,Segmentation),应用程序管理(如C++,Java,.net的内存管理机制).鉴于篇幅和笔者水平的限制,本文只涉及了内存管理的很小一部分,即.net中的内存管理方法..net是一个当代的应用程序框架,采用了内存自动管理