中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > .NET > 临时文章
关于DotNet的GC、Dispose
作者:未知 时间:2005-07-27 21:30 出处:CSDN 责编:chinaitpower
              摘要:关于DotNet的GC、Dispose

关于GC

.NETGC机制有这样两个问题:

首先,GC并不是能释放所有的资源。它不能自动释放非托管资源。

第二,GC并不是实时性的,这将会造成系统性能上的瓶颈和不确定性。

为了解决第一个问题,.NET提供了析构函数,在C#中是~ClassName的形式。如果某个类定义了析构函数,.NET会在第一次的GC中调用析构函数,第二次才真正进行资源释放。这就允许了我们能够做一些手动的资源管理操作,手动对非托管资源进行清理。但是如果没有必要,定义析构函数就会对性能造成较大的影响。

仅仅依赖析构函数对非托管资源进行释放是不够的,这是由于第二个问题:GC并不是实时性的,这会造成系统性能上的瓶颈和不确定性。所以有了IDisposable接口,IDisposable接口定义了Dispose方法,这个方法用来供程序员显式调用以释放非托管资源。

通常我们应该这样写程序:

        public class SampleClass : System.IDisposable

        {

                public void Dispose()

                //供程序员显式调用的Dispose方法

                {

                        Dispose(true);

                        //调用带参数的Dispose方法,释放托管和非托管资源

                        System.GC.SuppressFinalize(this);

                        //手动调用了Dispose释放资源,那么析构函数就是不必要的了,这里阻止GC调用析构函数

                }

                protected void Dispose(bool disposing)

                //protectedDispose方法,保证不会被外部调用。

                //传入booldisposing以确定是否释放托管资源

                {

                        if (disposing)

                        {

                                //在这里加入清理"托管资源"的代码,应该是xxx.Dispose();

                        }

                        // 在这里加入清理"非托管资源"的代码

                }

                ~SampleClass()

                //GC调用的析构函数

                {

                        Dispose(false);

                        //释放非托管资源

                }

        }

        这样一来,我们就像Delphi里调用Object.Free方法一样自然的调用Object.Dispose方法,而即使我们忘记了在合适的时候调用DisposeGC也会在释放对象的时候帮我们清理非托管资源的。GC所充当的角色只是一种保障手段,它应该充当这种角色,我们不能过分依赖它。

        实际上,在较大的模块退出时我们还应该及时地手动调用GC.Collect进行垃圾回收。


关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有