[C++]资源管理

资源管理

所谓资源就是,一旦使用了它,将来必须归还给系统!C++最常见的资源就是动态分配内存,如果不归还就会内存泄露。

1. 以对象管理资源

我们通常希望有一个对象来帮助我们解决资源管理的问题(自动调用析构函数),于是此章我们讨论auto_ptr和shared_ptr。

问题产生

假设我们希望使用一个工厂方法如:

class investment {
  ...};  // 代表一个root class
investment* creatinvestment() {  //  返回一个指针指向继承体系内动态分配的对象。
    ...
}
void f() {
    investment* pInv = createinvestment();
    ...
    delete pInv;
}

乍看起来这个函数并没有什么问题,正常的动态分配了对象,同时也删除了该对象。但问题在于…中可能出现异常情况,例如,提前的return,异常抛出,某个循环的continue等等,使得控制流无法读到delete语句,如此便出现了内存泄露。所以“单纯地以来f总是会执行其delete语句”是行不通的。

解决问题

为了解决这个问题,我们希望能把资源放入对象中,使得对象在离开其作用域时自动调用析构函数。于是,我们使用了auto_ptr。

void f() {
    std::auto_ptr<investment> pInv(createinvestment());
    ...
}
//  经由auto_ptr的析构函数自动删除pInv。

这个简单的例子示范了“以对象管理资源”的两个关键想法:
* 获得资源后立刻放进管理对象内。此观念常被称为“资源取得时机便是初始化时机”(RAII准则),因为我们几乎总是在取得一笔资源后同一语句内以它初始化某个对象。
* 管理对象运用析构函数确保资源被释放。不管控制流如何离开作用域,一旦对象被销毁,其析构函数自然会被自动调用,于是资源被释放。

然而,使用auto_ptr也需要注意,一定不能让多个auto_ptr指向同一个对象!因为每一个auto_ptr都会使用析构函数,他并不像智能指针一样会管理有多少指针指向同一对象。并且与copy相关的操作都会使原来的指针指向null,如此使对象只有一个auto_ptr指向。

基于auto_ptr的特性,我们便不能子啊STL容器中使用auto_ptr。auto_ptr

void f() {
    std::shared_ptr<investment> pInv(createinvestment());
    ...
}
//  经由shared_ptr的析构函数自动删除pInv。

几乎和auto_ptr一样,但是相应的复制行为会正常了许多。

补充auto_ptr相关知识

C++的auto_ptr所做的事情,就是动态分配对象以及当对象不再需要时自动执行清理。
使用std::auto_ptr,要#include 。
以下是源码:

template<class T>
class auto_ptr
{
private:
    T*ap;
public:
    //constructor & destructor-----------------------------------(1)
    explicit auto_ptr(T*ptr=0)throw():ap(ptr)
    {
    }

    ~auto_ptr()throw()
    {
        delete ap;
    }
    //Copy & assignment--------------------------------------------(2)
    auto_ptr(auto_ptr& rhs)throw():ap(rhs.release())
    {
    }
    templat
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值