C++从析构函数抛出异常

发布于 2024-11-03 09:14:53 字数 1634 浏览 7 评论 0原文

这不是从析构函数抛出异常是否安全的问题。

http://www.parashift.com/c++-faq-lite /exceptions.html#faq-17.9 状态:

“在堆栈展开期间,所有这些堆栈帧中的所有本地对象都会被破坏。如果这些析构函数之一抛出异常(假设它抛出一个 Bar对象),C++ 运行时系统处于双输的境地:它是否应该忽略 Bar 并最终进入 } catch (Foo e) { 它最初的位置?它是否应该忽略 Foo 并寻找 } catch ( Bar e) { handler? 没有好的答案——任何一个选择都会丢失信息。”

IE:如果在堆栈展开期间引发另一个异常,则运行时系统将处于双赢的情况,因为“查找”的 catch 处理程序不明确。

当堆栈展开本身引发的异常位于 try/catch 块中时,上述情况是否存在“异常”?在这种情况下,没有歧义:

#include <iostream>
using namespace std;

class Component
{
public:
    ~Component()
    {
        cout << "In component destructor" << endl;
        try
        {
            throw 1;
        }
        catch (...)
        {
            cout << "Caught exception in component destructor" << endl;
        }
    }

};

class Container
{
public:
    ~Container()
    {
        cout << "In container destructor" << endl;
        Component component;
    }
}
    ;

int main()
{
    try
    {
        Container cont;
        throw 'a';
    }
    catch (...)
    {
        cout << "Caught main exception ok" << endl;
    }
return 0;
}

以下暗示了这一点,但我想知道是否有人知道相关的 C++ 标准部分。

http://publib.boulder.ibm.com/infocenter/comphelp/v8v101/index.jsp?topic=%2Fcom.ibm.xlcpp8a.doc%2Flanguage%2Fref%2Fcplr155.htm

“如果在堆栈展开期间析构函数抛出异常并且未处理该异常,则调用 Terminate() 函数。以下示例演示了这一点:”

This isn't a question on whether it's safe to throw an exception from a destructor.

http://www.parashift.com/c++-faq-lite/exceptions.html#faq-17.9 states:

"During stack unwinding, all the local objects in all those stack frames are destructed. If one of those destructors throws an exception (say it throws a Bar object), the C++ runtime system is in a no-win situation: should it ignore the Bar and end up in the } catch (Foo e) { where it was originally headed? Should it ignore the Foo and look for a } catch (Bar e) { handler? There is no good answer — either choice loses information."

IE: if during stack unwinding another exception is thrown, then the runtime system is in a no-win situation because the catch handler to 'look for' is ambiguous.

Is there an 'exception' to the above, when the exception that is thrown during stack unwinding itself is in a try/catch block? In this case there is no ambiguity:

#include <iostream>
using namespace std;

class Component
{
public:
    ~Component()
    {
        cout << "In component destructor" << endl;
        try
        {
            throw 1;
        }
        catch (...)
        {
            cout << "Caught exception in component destructor" << endl;
        }
    }

};

class Container
{
public:
    ~Container()
    {
        cout << "In container destructor" << endl;
        Component component;
    }
}
    ;

int main()
{
    try
    {
        Container cont;
        throw 'a';
    }
    catch (...)
    {
        cout << "Caught main exception ok" << endl;
    }
return 0;
}

The following implies it, but I was wondering if anyone knew of the relevant C++ standard sections.

http://publib.boulder.ibm.com/infocenter/comphelp/v8v101/index.jsp?topic=%2Fcom.ibm.xlcpp8a.doc%2Flanguage%2Fref%2Fcplr155.htm

"If during stack unwinding a destructor throws an exception and that exception is not handled, the terminate() function is called. The following example demonstrates this:"

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

瀞厅☆埖开 2024-11-10 09:14:53

您的组件析构函数是安全的。您引用的规则仅适用于从析构函数(即析构函数的调用者)抛出异常

的情况。编辑:这是来自 标准(强调已添加)

注意:如果析构函数在
堆栈展开退出
异常,std::terminate 被调用
(15.5.1)。

Your Component destructor is safe. The rule you're quoting only applies if the exception is thrown out of the destructor (i.e., to the destructor's caller.)

EDIT: Here's one relevant quote from the standard (emphasis added)

Note: If a destructor called during
stack unwinding exits with an
exception, std::terminate is called
(15.5.1).

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文