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