zoukankan      html  css  js  c++  java
  • CLR GC

    Mark-Compact 标记压缩算法

    • Mark-Sweep 标记清除阶段:先假设heap中所有对象都可以回收,然后找出不能回收的对象,给这些对象打上标记,最后heap中没有打标记的对象都是可以被回收的.
      • 从线程正在使用的对象(roots)出发,依次递归访问所有引用对象(Reachable objects),所有被访问的对象均不可回收。
    • Compact 压缩阶段:对象回收之后heap内存空间变得不连续,在heap中移动这些对象,使他们重新从heap基地址开始连续排列,类似于磁盘空间的碎片整理。

    Generational 分代算法

    • Gen 0代:所有新生成的小于85000字节的对象。
    • Gen 1代:所有经过Gen 0代GC后保存下来的对象。
    • Gen 2代:所有经过Gen 1代GC后保存下来的对象,所有大于等于85000字节的新对象。

    GC触发条件

    • 区域内存达到阈值。
    • 手动调用 GC.Collect。
    • Finalizer 线程收到了 LowMemory 的异步通知。

    非托管资源

    • 继承IDispose实现Dispose方法。可供调用方手动调用,同时可通过析构函数调用保证未手动调用时资源及时释放。
  • 相关阅读:
    友元函数
    异常处理
    RTTI
    接口类
    纯虚函数和抽象类
    虚函数与虚析构函数原理
    查看表空间使用率及shrink 表空间
    RAC fail over 测试
    js判断数组中是不是有某个元素
    layui 表格图片放大
  • 原文地址:https://www.cnblogs.com/fuxuyang/p/11679307.html
Copyright © 2011-2022 走看看