我们最终找到了更多关于这个的信息(但是到那时我的机器已经被重新构建并丢失了cookie到我未注册的配置文件中;希望它能让Met发布这个答案)。
进一步的调查最终发现了一些我们认为有帮助的事件:
System.Windows.Forms.Application.ThreadExit
-当消息循环退出时激发
System.Windows.Forms.Application.ApplicationExit
-在所有消息循环退出时激发
System.AppDomain.CurrentDomain.DomainUnload
-在默认域以外的域退出时激发
System.AppDomain.CurrentDomain.ProcessExit
-在默认应用程序域退出时激发
System.AppDomain.CurrentDomain.UnhandledException
-在发生未捕获异常时激发,结束应用程序。
只有其中一个
DomainUnload
或
ProcessExit
对于给定的应用程序域,事件是可能的,这取决于它是进程的默认(顶级)域还是创建为子域(如在Web服务器上)。如果一个应用程序不知道它可能是哪个(在我们的例子中),那么如果它想自己捕获实际的卸载,就需要订阅这两个应用程序。而且,似乎
UnhandledException
(从.net2.0开始总是致命的)可能会阻止其他两个事件,因此这可能是第三个需要处理的情况。这三个事件适用于任何.NET应用程序。
有一个警告是
进程出口
有界(大约4秒?),因此可能无法在该事件处理程序中执行广泛的“最终”工作。它需要一些可以迅速完成的事情。
这个
Application
事件仅适用于WinForms应用程序(但我们怀疑它们可能不适用于纯WPF应用程序)。命名可能会产生误导,因为它们是以最基本的正常用法命名的,具有某些假设。
ThreadExit
与实际情况无关
System.Threading.Thread
而不是信息循环(
Application.Run()
))用户界面线程,以及
ApplicationExit
与一个或多个UI线程上的应用程序表单集合类似。通常,一旦呼叫
应用程序.run()
返回,从线程的entry方法调用,entry方法快速结束,然后线程本身结束。一旦所有的UI线程都退出,WinForms应用程序通常都会完成并退出。
另一个值得注意的事件是
System.Windows.Forms.Application.ThreadException
事件。可以将Windows消息循环配置为捕获处理消息时发生的异常并发送此事件,而不是让它们成为未捕获(因而是致命的)异常。捕获这些异常允许消息循环(和该UI线程)继续运行(在中止当前消息处理程序之后)。对于给定线程,任何时候只能有一个此事件的订阅服务器(订阅覆盖任何以前的订阅服务器),并且在创建和订阅任何表单之前必须对其进行配置,然后才能进入消息循环。请参阅此事件的msdn帮助,以及
System.Windows.Forms.Applicaton.SetUnhandledExceptionMode()
更多信息。