关闭

垃圾回收

838人阅读 评论(0) 收藏 举报

 .net垃圾回收要区别代码是托管代码或是非托管代码。在回收期间,如果垃圾回收器在托管代码中找到对某对象的一个或多个引用,
则不会释放该对象。垃圾回收器不识别非托管代码中对对象的引用,因此,除非明确禁止,否则它有可能释放非托管代码中以独占
方式使用的对象(GC无法回收非托管资源?)。(KeepAlive 方法提供一种机制,该机制可防止垃圾回收器回收在非托管代码中仍使用的对象。)


对于托管代码垃圾回收器会回收废弃对象,在回收废弃对象的的时候,垃圾回收器首先要检查该对象有无析构函数,如果没有就立即
回收,如果有,就把该对象的引用放入一托管回收列表中,当垃圾回收器检查完后,就开始清理托管列表中的对象,但并不马上回收内
存,要等到下一次垃圾回收器检查废弃对象的时候,才全部回收内存。


对于非托管资源,可以使用Finalize方法,.NET Framework 提供Finalize方法,它允许对象在垃圾回收器回收该对象使用的内存
时适当清理其非托管资源。C#中显性地调用finalizer是不允许的,它只能被碎片收集程序调用。如果希望尽快地释放一些不再使用
的数量有限的非托管资源(如文件句柄),则应该使用IDisposable接口,这一接口有个Dispose方法,它能够帮你完成这个任务。
Dispose是无需等待Finalize被调用而能够释放非托管资源的方法。Dispose方法的实现请采用微软所推荐的public   Dispose()和
private   Dispose(   bool   disposing   )。


任务管理器显示的是物理内存占用量,不包括页面文件上交换过去的内存,也不完全都是程序自己占用的,有些内核对象占用的空间也
被计算在内。窗口最小化时内存占用量下降,是因为Windows自动把程序此进程不常用的内存交换到页面文件,把内存空间让给活动窗
口这个特性对于所有Windows程序默认都一样(除非通过SetProcessWorkingSetSize   API直接指定working   set大小),当然也包括
.NET程序 。 GC.Collect方法并不保证回收所有无法访问的内存  
   
  可以这么写(这个技巧来自《.NET   框架程序设计》):  
  //   先强制回收一次内存(内存仍未释放,因为对象还要"复苏",然后执行Finalize方法)  
  GC.Collect();  
  //   等待所有对象的Finalize方法调用完成  
  GC.WaitForPendingFinalizers();  
  //   再次回收(此时内存空间才会被真正释放)  
  GC.Collect();  

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:27647次
    • 积分:368
    • 等级:
    • 排名:千里之外
    • 原创:6篇
    • 转载:12篇
    • 译文:0篇
    • 评论:4条
    文章分类