Effective C++ 条款8

本文探讨了在析构函数中处理异常的重要性,特别是在容器销毁过程中。若析构函数抛出异常,则可能导致内存泄露或其他不明确行为。文章提供了两种解决策略:一是通过调用abort()终止程序;二是捕获并记录异常。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

别让异常逃离析构函数

为什么别让异常逃离析构函数,异常逃离析构函数会引发哪些问题?很明显,异常会带来不明确的行为。
如下代码:
当容器销毁时会调用析构函数,这时如果析构函数抛出异常,容器中剩余的元素还是应该被销毁,否则可能会有内存泄露。这时如果继续销毁其他元素,又出现异常的话,会同时存在两个异常。两个异常同时存在会导致不明确的行为。使用标准库的其他容器或TR1的任何容器或者array,也会遇到类似的问题。我们此时需要做的一般情况下就是终止程序,以防止程序出现不明确行为

class Widget{
public:
……
~Widget(){……}
};

void doSomething()
{
    std::vector<Widget> v;
    ……
    //v要析构,会调用Widget的析构函数
}

在析构函数中,有的时候难免会抛出异常,如书上例子:
当数据库关闭失败时我们应该怎么办?

class DBConnection
{
public:
……
void close();//关闭数据库
};

class DBConnection
{
public:
……
    ~DBConn()//析构函数关闭连接
    {
        db.close();
    }
private:    
    DBConnection db;
};

有两个方法可以避免这个问题:
1、如果close抛出异常,就终止这个程序。通常通过调用abort完成。
2.吞下这个异常,这是个坏方法。

~DBConn()//析构函数关闭连接
    {
        try{
            db.close();
        }
        catch(……)
        {
            //记录下对close调用的失败
            std::abort();//退出
        }

    }

~DBConn()//析构函数关闭连接
    {
        try{
            db.close();
        }
        catch(……)
        {
            //记录下对close调用的失败
        }

    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值