条款13:以对象管理资源

对于这样的一个函数:

void f()

{

    int *pi = create();        //create函数返回一个指向动态分配的整形变量指针

    。。。。。。。。。。

    delete pi;

}

 

        如果中间程序过早出现return语句,那么动态内存没有及时释放掉,产生了内存泄露;右或者是中间程序的语句抛出异常,也不会执行delete语句;再或者delete语句在一个循环或者switch语句中执行了break、continue(只有循环语句)都会跳过delete语句。

       为了确保动态申请的资源总被释放,需要将资源放进对象对,利用对象的构造函数接管这片资源,利用析构函数释放这片资源。于是就有了“智能指针”:类指针对象auto_ptr

void f()

{

    std::auto_pt<int> pi( create() );

    。。。。。。。。。。。

}

       这样pi对象的构造函数里接管了create函数里面分配的动态内存,无论控制流如何退出f函数,都会调用对象的析构函数销毁这片动态内存。

       但是,这里不能让多个auto_ptr同时指向同一个对象。否则会造成未定义行为。于是C++中对其做了限制:若通过copy构造函数或赋值操作符复制它们,它们会变成null,而复制所得的指针将取得资源的唯一拥有权。

 

 

     auto_ptr的替代方案是“引用计数型智能指针”RCSP。即持续追踪共有多少对象指向某个资源,并在无人指向它时自动删除该资源。

        但是在程序设计时最好在哪里申请内存就在哪里释放,因为在用户不知道create函数返回的是动态申请的内存,可能不会使用智能指针等机制确保内存释放。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值