我有一个带有单个Editor
类的Windows窗体应用程序(继承自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中的调试模式中中断。要对此进行测试,我只在throw new Exception()
的静态构造函数中添加了ConnectionManager
。使用ConnectionManager
并因此在Editor_Load
事件处理程序中初始化(第一次)。调用静态构造函数并抛出异常(仅在输出窗口中可见)。正如预期的那样,Editor_Load
事件处理程序(cmbConnections.Visible = false;
)的其余部分未执行。
但我不明白的是为什么我的VS2010吞下了这个例外?它没有破坏调试。它没有包含在任何try / catch块中。它继续在主窗口执行程序。看起来似乎Editor_Load
在另一个线程上执行了。
我可以在输出窗口中看到消息:
Editor.exe
中出现'System.InvalidOperationException'类型的第一次机会异常Editor.exe
中出现'System.TypeInitializationException'类型的第一次机会异常
但执行只是在调试模式下没有中断。
以下是我认为可能影响此行为的一些选项:
项目属性 - >构建 - >一般 - >优化代码是UNCHECKED。
工具 - >选项 - > Debugging->常规 - >启用Just My Code已检查。
在例外设置中,“user-unhandled”的复选框为CHECKED。
我错过了什么吗?这种行为是否正常?我认为VS2010会抛出任何未处理的异常。在这里,这个没有处理,仍然没有打破。
答案 0 :(得分:1)
我认为您需要在“例外”对话框中启用“托管(.NET)异常”“抛出”( Ctrl-Alt-E )。 1
为了避免许多虚假(处理)异常,我通常会尝试接近初始化程序运行的位置,然后在继续之前检查该复选框。
此外,如果存在加载程序异常,请务必检查异常中的嵌套内部异常或加载程序信息:异常本身通常不具备信息性。为了得到实际的错误,我经常不得不深入研究2层或更多层的包装异常。
1 我只能猜 为什么;我的感觉是静态类型初始化器不被认为是确定性运行的(许多事情可能触发它并且顺序通常是未定义的;只是保证类型的静态构造函数在使用之前已经运行,但它几乎可以在代码的任何一点使用,而你不知道或明显地触发它。)
因此,运行时很难确定它是否是“由用户代码处理”(没有用户期望处理它,因为它不知道 - 确定性 - 当初始化程序将运行时)。
然而,这是我的猜想。