我遇到了一个应用程序挂起的问题,并给了我默认的“请告诉 Microsoft 这个问题”弹出窗口,而不是应用程序中的“未处理的异常”对话框。
在应用程序代码中,Application.ThreadException 和 AppDomain.CurrentDomain.UnhandledException 都被重定向到将错误日志写入磁盘、将屏幕截图保存到磁盘并显示友好对话框的方法。
但是当这个错误发生时,这三件事都不会发生。我在事件查看器中得到的只是这个:
EventType 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 来证明这一点。现在添加了一个标志以防止在错误处理中重新进入,我似乎不再有问题......