当前位置: 首页 > 图文教程 > 开发语言 > C/C++ > 代码最优化.NET中的内存管理

C/C++
2009年编程开发语言的使用率
C++对象模型笔记:dynamic binding
cstl -- c语言编写通用数据结构和常用算法库(模仿SGI STL)
子串匹配:不回溯算法
C++ Builder 访问 USB 口的方法
C++中二维数组的动态分配
数组和指针在编译的时候的区别
如何利用doxygen生成pdf文档
有关C++析构函数的异常(Exceptions in Destructors)
C++模板学习之函数对象之谓词
5月编程语言排行榜:D语言风采不再
一个C++类实现文件全盘搜索
C语言编程宝典之一 读书笔记
C语言嵌入式系统编程修炼(内存操作)
C++内存管理
带头结点的双循环链表
有关VA_LIST的用法
C++标准库简介(转)
一个栈类的实现(链栈)
C 引用与指针的比较

C/C++ 中的 代码最优化.NET中的内存管理


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 292 ::
收藏到网摘: n/a

在.NET中,内存管理是自动进行的。内存的再收集属于后台任务,这使开发者们更专注于手边的工作。在这篇文章中,我们来看一看为开发者提供帮助并且控制垃圾收集的接口。

 

处理设计模式(Dispose design pattern): IDisposable, Dispose, Finalize

 共同语言运行时(CLR)无法清理数据库连接、窗口句柄、文件句柄一类的资源。因此,为开发者提供清理这类难管理的资源的机制是很有必要的。清理工作可以在Finalize方法中实现,Finalize方法在C#语言中被实现为垃圾破坏者。该方法的调用在垃圾收集器的控制下进行。

通常,你会需要一个确定的方法来清理像文件句柄一类难管理的资源。例如,现在你打开了一个文件进行写操作,当你结束将文件内容载入缓冲器后,你可能需要明确的关闭文件句柄。对于这类显式清理,.NET提供了处理设计模式(dispose design pattern

需要进行显示清理的对象需实现IDisposable接口。IDisposable接口提供了Dispose方法,该方法不像Finalize方法,它不在开发者的控制之下。

既然Dispose方法的调用是显示清理,使用垃圾收集器收集这些对象没有必要。因此Dispose方法应该包含一个对GC.SuppressFinalize()的调用,提示垃圾收集器在这个对象上不需要使用Finalize方法。

推荐在一个需要进行显示清理的对象上同时实现Finalize Dispose方法。Finalize方法在Dispose方法没有被调用时提供一个备份的机制。垃圾收集器将执行对象的终结和防止难管理的资源的永久性泄漏。

 


Listing A中的代码片断更清晰的描述了这些概念。

在Listing A中,SampleClass类使用了一个文件句柄,这是一个难管理的资源。因此,应为该对象实现IDisposable接口和提供Finalize方法。

用来清理文件句柄的代码是Dispose方法的一部分。GC.SuppressFinalize()在难管理资源被清除时也将被调用。

该类同时提供了垃圾破坏器(Finalize方法),也包含了用于清理难管理资源(文件句柄)的代码。

弱引用
 

.NET框架提供了另一有趣的特色,被用于实现多样的高速缓存。在.NET中弱引用通过System.WeakReference类实现。弱引用为引用的对象提供一项机制,使被引用的对象能够被垃圾收集器作用。ASP.NET高速缓存就使用了弱引用。如果内存使用率太高,高速缓存将被清除。

 

强制垃圾收集

 

.NET框架为开发者提供System.GC类来控制垃圾收集器的一些方面。垃圾收集可以通过调用GC.Collect方法强制执行。通常建议不要手动的调用垃圾收集器,而将其设置为自动方式。在某些情况下,开发者会发现强制垃圾收集将推进性能。但是,使用这个方法需要非常小心,因为在垃圾收集器运行时将延缓当前执行的线程。GC.Collect方法不应位于可能被经常调用的地方。这样做将使应用程序的性能降级。

.NET中的服务器和工作站版本

.NET构架包括相同的CLR的两种版本,分别对应于特定的目的。将他们分类为服务器运行时和工作站运行时,并分别在mscorsvr.dllmscorwks.dll中实现。服务器版的CLR利用