- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我刚刚在 .NET 2.0 应用程序中修复异常处理,我偶然发现了一些奇怪的问题 Application.ThreadException .
我想要的是能够从 GUI 元素(例如 button_Click 等)后面的事件中捕获所有异常。然后我想根据“致命性”过滤这些异常,例如对于某些类型的异常,应用程序应该继续运行,而对于其他类型,它应该退出。
在另一个 .NET 2.0 应用程序中,我了解到,默认情况下,只有在 Debug模式下,异常才会真正离开 Application.Run 或 Application.DoEvents 调用。在 Release模式下,这不会发生,并且必须使用 Application.ThreadException 事件“捕获”异常。
然而,现在我注意到 Application.ThreadException 事件的 ThreadExceptionEventArgs 中传递的异常对象始终是异常链中最内层的异常 .出于日志记录/调试/设计目的,我确实想要整个异常链。例如,当您刚刚处理 SocketException 时,确定哪个外部系统失败并不容易:当它被包装为例如时一个 NpgsqlException,那么至少你知道这是一个数据库问题。
那么,如何从这个事件中获取整个异常链呢? 甚至可能还是我需要以另一种方式设计我的异常处理?
请注意,我确实 - 有点 - 有一个 workaround使用 Application.SetUnhandledExceptionMode ,但这远非理想,因为我必须滚动自己的消息循环。
编辑:为了防止更多错误, GetBaseException() 方法没有做我想要的 :它只返回最里面的异常,而我唯一已经拥有的是最里面的异常。我想得到最外面的异常!
最佳答案
这个问题的措辞和回答更有用:
Why does the inner exception reach the ThreadException handler and not the actual thrown exception?
关于.net - 如何在 Application.ThreadException 事件处理程序中获取整个异常链?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61354/
当抛出异常并在 Application.ThreadException 事件处理程序中捕获它们时,我看到了一些奇怪的行为。 基本上下面示例中发生的事情是在 BackgroundWorker 的 DoW
当抛出异常并在 Application.ThreadException 事件处理程序中捕获它们时,我看到了一些奇怪的行为。 基本上下面示例中发生的事情是在 BackgroundWorker 的 DoW
我刚刚在 .NET 2.0 应用程序中修复异常处理,我偶然发现了一些奇怪的问题 Application.ThreadException . 我想要的是能够从 GUI 元素(例如 button_Clic
我最近在我的C#(WinForms)应用程序中实现了一些(基本)未处理的错误处理程序。 UnhandledExceptionEventHandler工作正常,但是在ThreadExceptionEve
我有一个来自应用程序的窗口,带有这样的 program.cs 代码: static class Program { /// /// The main entry point for
我们有一个很大的应用程序,为了确保我们的客户不会收到“XXX 已停止工作”的消息,我们添加了一些处理程序(我们在其中记录了一些错误和一些其他内容)。 它工作正常,我们已经解决了很多这样的问题(通过分析
我正在使用 Application.ThreadException在我的 winforms 应用程序中处理和记录意外异常的事件。 现在,在我的应用程序中的某个地方,我得到了以下代码(或者更确切地说,是
Application.ThreadException的reference page说 Because this is a static event, you must detach your eve
我有一个方法,可以从网络获取Object,然后使用此数据更新UI。 我使用第三方API来获取数据并接收数据。下载过程在新的 Thread 中完成,获取和更新数据在 UI Thread 中完成。 在我的
首先是一些背景知识:我有一个多线程 WinForms 应用程序,它正在与 native dll 进行互操作。此应用程序有时会因未处理的异常而崩溃,我们正在尝试调查为什么会发生这种情况。为了方便它,我正
我不明白为什么在 VS2010 中使用 (CTRL-F5 - Run without Debugger) 在以下情况下只得到 1 个消息框: Public Class Form1 Privat
我有一个 WinForms 应用程序,它创建了多个表单,每个表单都在自己的 GUI 线程(而不是主 GUI 线程)中。我想处理所有这些表单的未处理异常事件 (Application.ThreadExc
好吧,这是一个简单的: Application.ThreadException 和 AppDomain.CurrentDomain.UnhandledException 有什么区别>? 我需要同时处理
似乎在属性的 Set 方法中发生的异常不会冒泡到应用程序的 ThreadException 事件。 我们将该事件与 AppDomain.CurrentDomain.UnhandledException
我遇到了一个应用程序挂起的问题,并给我默认的“请告诉微软这个问题”弹出窗口,而不是应用程序中的“未处理的异常”对话框。 在应用程序代码中,Application.ThreadException 和 A
在我使用的 WinForms 中: System.Windows.Forms.Application.ThreadException System.Windows.Application.Unhand
是否有任何理由更喜欢在 Windows 窗体应用程序中实现全局异常处理程序的这些方法中的一种而不是另一种? 第一种方法 static void Main(string[] args) { tr
我是一名优秀的程序员,十分优秀!