0

我有一个类,它的构造函数会抛出异常。我还有一个 catch 块来处理该异常。但是,我仍然看到异常被传播回调用者,即使它已被处理。我知道,应该有一个异常通知调用者构造失败。但在这种情况下,它(重新抛出)是如何发生的?

class Test
{
    public:
        Test()
        try
        {
            std::cout << "in child constructor" << std::endl;
            throw 3.2;
        }
        catch(int &e)
        {
            std::cout << "in int catch: " << e << std::endl;
        }
        catch (double &e)
        {
            std::cout << "in double catch: " << e << std::endl;
        }
};

int main (void)
{
    try
    {
        Test obj;
    }
    catch (int &e)
    {
        std::cout << "in main int catch: " << e << std::endl;
    }
    catch (double &e)
    {
        std::cout << "in main double catch: " << e << std::endl;
    }

    return 0;
}

我得到的输出是

in child constructor
in double catch: 3.2
in main double catch: 3.2
4

1 回答 1

2

根据标准,这是正确的。n3337.pdf 的第 15.3 节第 15 点内容如下:

如果控制到达构造函数或析构函数的函数尝试块的处理程序的末尾,则重新抛出当前处理的异常。否则,当控制到达 function-try-block (6.6.3) 的处理程序末尾时,函数返回。从函数try块的末尾流出相当于没有值的返回;这会导致值返回函数 (6.6.3) 中的未定义行为。

可以完全捕获并防止异常在构造函数/析构函数体内传播。但是,您无法以这种方式捕获从基类/成员构造函数/析构函数抛出的异常。

于 2013-07-11T18:45:32.530 回答