【发布时间】:2010-10-08 18:41:29
【问题描述】:
我有一个 WPF 窗口,我通过调用 Show() 从另一个窗口创建它,然后让它 Close() 本身。当窗口关闭时,我预计它会死掉,调用它的析构函数,并删除它的所有子元素(例如计时器..)。
调用此类操作的正确方法是什么?
【问题讨论】:
我有一个 WPF 窗口,我通过调用 Show() 从另一个窗口创建它,然后让它 Close() 本身。当窗口关闭时,我预计它会死掉,调用它的析构函数,并删除它的所有子元素(例如计时器..)。
调用此类操作的正确方法是什么?
【问题讨论】:
关于Window持有的资源,根据documentation:
(强调)
关闭窗口会引发 Closing 事件。如果收盘 事件未取消,会发生以下情况:
从 Application.Windows 中删除窗口(如果应用程序 对象存在)。
如果所有者/拥有者,则从所有者窗口中删除窗口 在显示拥有的窗口之前建立关系并且 所有者窗口打开后。
引发了 Closed 事件。
由 Window 创建的非托管资源被释放。
如果调用 ShowDialog 来显示窗口,则 ShowDialog 返回。
我相信这是按顺序列出的。
我不确定计时器子问题的具体情况;我认为这个问题没有足够的细节来真正回答这个问题。
【讨论】:
以防万一,我会加两分钱。
我的问题是我没有进行足够的故障排除。我的窗口是一个可以打开、关闭和重新打开的子窗口,所以我添加了以下内容以防止它完全关闭:
private void Window_Closing(object sender, System.ComponentModel.CancelEventArgs e) {
e.Cancel = true;
this.Hide();
}
但是,当 Window.Close 被调用时,它只是隐藏了窗口。我最终理解并添加了以下内容:
private void Window_Closing(object sender, System.ComponentModel.CancelEventArgs e) {
e.Cancel = true;
this.Hide();
}
public void Close() {
this.Closing -= Window_Closing;
//Add closing logic here.
base.Close();
}
这很好 - 它删除了阻止窗口关闭的事件处理程序,然后将其关闭。
【讨论】:
Window.Close 方法。最好有一个单独的方法来做同样的事情。
Window.Close 完全是故意的,因为调用隐藏方法会导致意外和不正确的行为。
关闭窗口并确信您已向其释放所有资源及其任何子级将导致逻辑树中所有表现良好的元素被垃圾回收。
我说“表现良好”是因为理论上可以有一个元素执行诸如创建一个未正确停止的线程之类的操作,但实际上,如果您使用的是基本的 WPF 框架和编写良好的控件,您应该放开一切就好了。
【讨论】:
与 Windows 窗体不同,实际上需要显式释放的 WPF 元素很少。
对于 Window,调用 Close() 足以根据 documentation 处理所有托管和非托管资源。
【讨论】: