如果不用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;
}
當然可能有其他的方法,各位看客有興趣的話補充一下。另外有敘述不當的地方,請多多指教,在下感激不盡。
新聞熱點
疑難解答
圖片精選