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