VS2010没有打破静态构造函数异常的调试
我有一个Windows窗体应用程序与单个Editor
类(从Form
继承)。
public partial class Editor : Form
{
public Editor()
{
InitializeComponent();
Load += Editor_Load;
}
private void Editor_Load(object sender, EventArgs e)
{
cmbConnections.DataSource = ConnectionManager.Connections;
cmbConnections.Visible = false;
}
}
除了设计器生成的代码外,这是表单的唯一代码(仅包含一个组合框( cmbConnections
))。
ConnectionManager
类是具有静态构造函数的静态类。 它的构造函数会进行一些初始化,然后测试一些关键条件。 如果条件满足,构造函数将引发异常。 但是,这个异常在Visual Studio 2010的调试模式下不会中断。为了测试这个,我只在ConnectionManager
的静态构造函数中放置了throw new Exception()
。 ConnectionManager
被使用并因此在Editor_Load
事件处理器中被初始化(第一次)。 调用静态构造函数并引发异常(仅在输出窗口中可见)。 Editor_Load
事件处理程序( cmbConnections.Visible = false;
)的其余部分Editor_Load
预期执行。
但是我不明白的是为什么我的VS2010吞下异常? 它没有打破调试。 它不包含在任何try / catch块中。 它继续在主窗口中执行程序。 它看起来好像Editor_Load
在另一个线程上执行。
我可以在输出窗口中看到消息:
在Editor.exe中发生类型为“System.InvalidOperationException”的第一次机会异常
在Editor.exe中发生第一次机会例外类型'System.TypeInitializationException'
但执行在调试模式下不会中断。
以下是我认为可能会影响此行为的一些选项:
Project Properties-> Build-> General-> Optimize code is UNCHECKED。
工具 - >选项 - >调试 - >常规 - >启用只是我的代码被检查。
在例外设置中,“用户未处理”的复选框被CHECKED。
我错过了什么吗? 这种行为是否正常? 我认为VS2010会抛出任何未处理的异常。 这里这个没有处理,仍然没有破坏。
我认为在设计中,您需要在异常对话框(Ctrl-Alt-E)中启用托管(.NET)异常'引发'.1
为了避免许多虚假(已处理)的异常,我通常会尽量接近初始化器运行的位置,然后在继续之前检查该复选框。
另外,如果有加载程序异常,请务必在异常中检查嵌套的内部异常或加载程序信息:异常本身通常不是那种提供信息的。 我经常不得不挖掘2层或更多层的包装异常,才能看到实际的错误。
1我只能猜测为什么是这样; 我的感觉是,静态类型初始化不被认为是确定性运行的(很多事情可能会触发它,而且顺序通常是未定义的;它只能保证类型的静态构造函数在使用前已经运行,但它可以是在代码中的几乎任何点使用,没有你知道或明确触发)。
因此,运行时很难确定它是否由'用户代码处理'(没有用户期望处理它,因为它不知道 - 确定性地 - 初始化器将运行时)。
然而,这是我的猜想。
链接地址: http://www.djcxy.com/p/27977.html上一篇: VS2010 did not break debug on static constructor exception
下一篇: Causing VS2010 debugger to break when Debug.Assert fails