智能型指针auto_ptr

本文探讨了auto_ptr的设计动机,旨在解决C++中因忘记释放动态分配的内存而导致的资源泄漏问题。通过示例代码展示了如何使用auto_ptr管理对象生命周期,并解释了auto_ptr所有权转移的机制。

auto_ptr的设计动机

      在一个函数中,有时会利用new和delete来产生和销毁对象。但是这经常会带来麻烦,因为程序员经常忘记delete动作。这还是算小的麻烦,当函数发生异常时,函数立即退离,根本不会调用函数尾端的delete语句。结果可能是内存遗失,或者说是资源遗失,因为没被释放。防止这种遗失的常见方法是捕捉所有的异常,在catch异常时还要处理对象的删除操作,会显得程序特别的麻烦,复杂而且容易出错,必须尽力避免。

 

       如果使用智能型指针,情况就会大不相同。智能型指针应该保证,无论在任何情况下,只要自己被摧毁,就一定连带释放其所有的资源。auto_ptr就是这样一种指针。

 

 

代码示例:

#include<memory>

void f()

{

        std::auto+ptr<ClassA> ptr(new ClassA);
}

不在需要delete语句。

 

 

 

auto_ptr拥有权的转移

 

代码示例:

#include<iostream>
#include<string>
#include<memory>
#include<utility>
using namespace std;


class Cat
{
 
private :
 int age;
public:
 Cat(int a):age(a){}
 ~Cat()
 {
  cout<<"linger"<<age<<endl;
 }
 void setAge(int a)
 {
  age=a;
 }
 int getAge()
 {
  return age;
 }
};

/*void f(auto_ptr<Cat> p)
{
 cout<<p->getAge()<<endl;
}
*/

void f(auto_ptr<Cat>& p)
{
 cout<<p->getAge()<<endl;
}


int main()
{
 auto_ptr<Cat> p(new Cat(1));

 auto_ptr<Cat> p2(p);//控制权应该在p2手中

 //cout<<p->getAge()<<"  1"<<endl;

// cout<<p2->getAge()<<"   2"<<endl;

 f(p2);
 cout<<p->getAge()<<"  1"<<endl;

 
 return 0;
}

 

当p把拥有权给p2以后,此时p和p2都能够访问Cat对象。但是p2对Cat对象有生死权。如果p被销毁,没关系,p2照样能访问,但p2被销毁,p就不能访问了

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值