首页 > 编程 > .NET > 正文

从小处看C#.net垃圾回收

2024-07-10 13:09:07
字体:
来源:转载
供稿:网友
中国最大的web开发资源网站及技术社区,

如果不用mdi来实现一个主窗体打开多个子窗体时,

从一个窗体(主窗体)打开一个(only one) 另外一个的窗体(子窗体)的实现

父窗体:mainform

public partial class mainform:form

{

    ............

 

    private void menuitem1_load(object sender,eventargs e)    

     {

        childform child1=childform.create();

        child1.show();

        child1.focus();

     }

  

    //......

}

 

子窗体:childform

 

public partial class childform:form

{

     .....

 

     static childform child;

    

     public static childform create()

      {

         if(child==null)

            child=new childform();

          return child;

      }

     ......

}

 

f5运行后,的确实现了上面提到的功能。然而,把子窗体关闭后,想再次打开该子窗体时,单击菜单项,会出现异常:objectdisposedexception was unhandled.

 

    这是为什么呢??

 

这里涉及到c#垃圾回收的问题:

 

垃圾回收是.net运行库的一部分。垃圾回收器管理所有的托管对象,所有需要托管数据的.net语言(包括 c#)都受运行库的垃圾回收器的制约。垃圾回收器可以确定运行垃圾回收的最佳时间,自动进行垃圾回收。然而垃圾回收的一个产物是:c# 对象没有确定性毁坏。所以会出现对象child已被销毁,但又不为null,访问时产生objectdisposedexception异常。

 

   怎么办??

 

   方法:应该彻底回收child所占的资源。

  途径有二:

方法一:

修改子窗体的构造函数

public childform()

{

      //.........

      this.disposed+=new system.eventhandler(form_disposed)

}

然后事件form_disposed的处理函数

private void form_disposed(object sender,eventargs e)

{

      child=null;

}

方法二:

重写childform的onclosed方法

protected void onclosed(eventargs e)

{


      base.onclosed(e); 
      child=null;

}

当然可能有其他的方法,各位看客有兴趣的话补充一下。另外有叙述不当的地方,请多多指教,在下感激不尽。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表