如果不用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;
}
当然可能有其他的方法,各位看客有兴趣的话补充一下。另外有叙述不当的地方,请多多指教,在下感激不尽。
新闻热点
疑难解答
图片精选