我遇到了应用程序挂起的问题,并给了我默认的“请告诉 Microsoft 有关此问题”的弹出窗口,而不是应用程序中的“未处理的异常”对话框。
在应用程序代码中,Application.ThreadException 和 AppDomain.CurrentDomain.UnhandledException 都被重定向到一个方法,该方法将错误日志写入磁盘、将屏幕截图保存到磁盘并显示友好的对话框。
但是当这个错误发生时,这三件事都不会发生。我在事件查看器中得到的只是:
事件类型 clr20e3、P1 myapp.exe、P2 4.0.0.0、P3 47d794d4、P4 mscorlib、P5 2.0.0.0、P6 471ebc5b、P7 15e5、P8 27、P9 system.argumentoutofrange、P10 NIL
鉴于该错误似乎只在应用程序运行几个小时后才会发生,我想知道这是否可能是内存泄漏问题。我搜索了一些“clr20e3”,但只找到了 ASP.Net 的东西。我的应用程序是 Windows Forms (.Net 2.0) exe,使用了相当多的程序集 - 使用 C# 和一些非托管 C++。
我想这也可能是错误处理方法中的错误 - 正如一些答案所建议的那样,我可能会尝试在错误处理程序的开头进行日志记录(但考虑到这几乎就是我所做的......)。
任何解决此问题的帮助都将不胜感激 - 无论是解决方案还是如何找出问题根本原因的建议。
更新:原始错误的根本原因是访问具有负索引的数组(即 system.argumentoutofrange)。为什么这没有被捕获对我来说有点神秘,但考虑到两个异常都被发送到相同的处理代码,我想知道是否可能不存在(例如)两者都被调用并争夺资源的情况(例如日志文件)?
我通过在错误处理代码中执行任何其他操作之前执行 EventLog.WriteEntry 来证明这一点。现在添加了一个标志以防止在错误处理中重新进入,我似乎不再有问题......