码迷,mamicode.com
首页 > 其他好文 > 详细

CLR GC

时间:2019-10-15 19:06:54      阅读:96      评论:0      收藏:0      [点我收藏+]

标签:mem   线程   final   条件   分代   pos   依次   gen   函数   

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方法。可供调用方手动调用,同时可通过析构函数调用保证未手动调用时资源及时释放。

CLR GC

标签:mem   线程   final   条件   分代   pos   依次   gen   函数   

原文地址:https://www.cnblogs.com/fuxuyang/p/11679307.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!