我已通过以下方式在启动例程中在我的应用程序(C#,WPF,.NET4)中注册了全局Exceptionhandler:
AppDomain.CurrentDomain.UnhandledException += (sender, args) => HandleException(args.ExceptionObject as Exception);
Application.Current.DispatcherUnhandledException += (sender, args) => {
HandleException(args.Exception);
args.Handled = true;
};
HandleException()记录Exception并显示带有一些附加信息的MessageBox。
现在,我的应用程序有时会在某些客户机器上崩溃,而不会调用HandleException()。 Windows显示以下消息:
在WindowsEventLog中,我收到以下条目:
条目1:
Name der fehlerhaften Anwendung: proconact.exe, Version: 1.0.0.1365, Zeitstempel: 0x511531df
Name des fehlerhaften Moduls: PresentationFramework.ni.dll, Version: 4.0.30319.588, Zeitstempel: 0x504db27d
Ausnahmecode: 0xc00000fd
Fehleroffset: 0x002ef05b
ID des fehlerhaften Prozesses: 0x1bec
Startzeit der fehlerhaften Anwendung: 0x01ce0b5dce4030a6
Pfad der fehlerhaften Anwendung: C:\Program Files (x86)\proconact_sck\proconact.exe
Pfad des fehlerhaften Moduls: C:\windows\assembly\NativeImages_v4.0.30319_32\PresentationFramewo#\c627e9b7f10b01db43645284e601f255\PresentationFramework.ni.dll
Berichtskennung: d8d69f94-777a-11e2-b4b0-b4b52f2aad4f
ENTRY2:
Fehlerbucket 3482664247, Typ 5
Ereignisname: CLR20r3
Antwort: Nicht verfügbar
CAB-Datei-ID: 0
Problemsignatur:
P1: proconact.exe
P2: 1.0.0.1365
P3: 511531df
P4: PresentationFramework
P5: 4.0.0.0
P6: 504db27d
P7: 329d
P8: 0
P9: System.StackOverflowException
P10:
Angefügte Dateien:
d:\Temp\WER6E9F.tmp.WERInternalMetadata.xml
Diese Dateien befinden sich möglicherweise hier:
C:\Users\roger\AppData\Local\Microsoft\Windows\WER\ReportArchive\AppCrash_proconact.exe_b0fabce1f86d1f843de5b5b4692a3e8ecd928_2c77f03d
Analysesymbol:
Es wird erneut nach einer Lösung gesucht: 0
Berichts-ID: d8d69f94-777a-11e2-b4b0-b4b52f2aad4f
Berichtstatus: 0
我可以做些什么来处理异常(为了获得用于分析的堆栈跟踪的异常原因)?
答案 0 :(得分:2)
有些异常无法捕获,甚至AppDomain.UnhandledException都没有。因为它们太难以让托管代码继续运行。
StackOverflowException就是这样的心脏病发作,臭名昭着,足以让这个网站得名。没有足够的堆栈空间来执行常见的托管代码执行任务,例如运行抖动。 ExecutionEngineException是另一个,由破坏的垃圾收集堆触发,在.NET 4.0及更高版本中无法访问。
所以不,节目结束了,WER对话框和Windows事件日志条目就是剩下要看的了。所以总是由一个错误引起,你需要修复它。