VS2010没有破坏静态构造函数异常的调试

时间:2012-02-09 23:11:29

标签: c# visual-studio-2010 exception-handling static-constructor swallowed-exceptions

我有一个带有单个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会抛出任何未处理的异常。在这里,这个没有处理,仍然没有打破。

1 个答案:

答案 0 :(得分:1)

我认为您需要在“例外”对话框中启用“托管(.NET)异常”“抛出”( Ctrl-Alt-E )。 1

为了避免许多虚假(处理)异常,我通常会尝试接近初始化程序运行的位置,然后在继续之前检查该复选框。

此外,如果存在加载程序异常,请务必检查异常中的嵌套内部异常或加载程序信息:异常本身通常不具备信息性。为了得到实际的错误,我经常不得不深入研究2层或更多层的包装异常。


1 我只能 为什么;我的感觉是静态类型初始化器不被认为是确定性运行的(许多事情可能触发它并且顺序通常是未定义的;只是保证类型的静态构造函数在使用之前已经运行,但它几乎可以在代码的任何一点使用,而你不知道或明显地触发它。)

因此,运行时很难确定它是否是“由用户代码处理”(没有用户期望处理它,因为它不知道 - 确定性 - 初始化程序将运行时)。

然而,这是我的猜想。