是什么导致UnhandledExceptionEventArgs.IsTerminating标志为true或false?

时间:2012-06-11 14:48:09

标签: c# .net clr

订阅AppDomain.CurrentDomain.UnhandledException上的活动时,哪些条件会导致UnhandledExceptionEventArgs IsTerminating标志为真?即什么导致异常被视为致命?

除非另有配置,否则默认情况下所有未处理的异常都是致命的?

3 个答案:

答案 0 :(得分:8)

此属性始终为true。在.NET 1.x时代,它曾经可能是虚假的。该版本允许线程在未处理的异常上死亡而不会使整个进程终止。这只是效果不好,程序员没有实现事件处理程序(或者不知道如何正确处理事件中的异常,谁这样做)所以线程刚刚死亡而没有任何通知。几乎不可能没有这个原因很难诊断程序失败。

Microsoft更改了.NET 2.0中的默认行为,未处理的异常终止了该程序。从技术上讲,仍然可以覆盖此行为,自定义CLR主机可以通过实现IHostPolicyManager接口使进程保持活动状态。默认主机支持<legacyUnhandledExceptionPolicy> config元素。不要使用它,那就是龙。

答案 1 :(得分:4)

不,来自另一个应用程序生成的托管线程的未处理异常会使IsTerminating等于false,因为它会终止线程而不是整个应用程序。这是我在这种情况下唯一一次看到IsTerminating是假的,MSDN page说这也是主要的用例。

答案 2 :(得分:0)

我将它用于测试目的。我想测试我的UnhandledExceptionHandler,它记录了Exceptions。 所以我设置它以便我可以记录消息,但不要击落测试线程。

但通常情况下,这意味着在我看到的所有其他情况下,IsTerminating标志都设置为true。