gpt4 book ai didi

c# - 通过 Application.ThreadException 和 AppDomain.CurrentDomain.UnhandledException 的异常

转载 作者:行者123 更新时间:2023-11-30 12:37:42 24 4
gpt4 key购买 nike

我遇到了一个应用程序挂起的问题,并给我默认的“请告诉微软这个问题”弹出窗口,而不是应用程序中的“未处理的异常”对话框。

在应用程序代码中,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 窗体 (.Net 2.0) exe,使用相当多的程序集 - 在 C# 和一些非托管 C++ 中。

我想这也可能是错误处理方法中的错误——正如一些答案所暗示的那样,我可能会尝试在错误处理程序开始时记录日志(但考虑到这几乎是我所做的......)。

任何解决此问题的帮助都将不胜感激 - 无论是解决方案,还是有关如何找出问题根本原因的建议。

更新:原始错误的根本原因是访问具有负索引的数组(即 system.argumentoutofrange)。为什么这没有被困住对我来说有点神秘,但考虑到这两个异常都被发送到相同的处理代码,我想知道是否可能存在(例如)两者都被调用并争夺资源的情况(例如日志文件)?

我设法通过在错误处理代码中的任何其他操作之前执行 EventLog.WriteEntry 来证明这一点。现在添加了一个标志以防止在错误处理中重新进入,我似乎不再有问题......

最佳答案

这里只是在黑暗中射击 - ArgumentOutOfRangeException 是否有可能实际上是从您的异常处理程序中抛出的?

此外,您没有说明问题是什么类型的应用程序——Application.ThreadException 只影响 WinForms 线程,所以如果这不是 GUI 应用程序,它就没用了。 (请参阅 MSDN documentation 中的备注部分)

关于c# - 通过 Application.ThreadException 和 AppDomain.CurrentDomain.UnhandledException 的异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/92434/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com