条款十三 以对象管理资源

1.管理动态分配内存

void TestFun()
{
  int *pval = new int(0);
  .... //此处省略一万代码...
  delete pval;
  pval = NULL; //这一边最好有,不然pval相当于执行一块被释放内存的空间,也就是野指针
}

  这里涉及到动态分配内存使用后回收问题,虽然上面函数中使用到delete,但不一定能被执行到,
在代码"...."中如果有分支(if,while, switch)中有return或者中途抛出异常,函数都会中断,
delete不会被执行,这就容易造成内存泄露,如果解决这个问题,可以使用"智能指针".

2.智能指针auto_ptr对资源管理

void TestFun()
{
  auto_ptr<int> pval(new int); //智能指针指向一块int类型数据内存
  .... //此处省略一万代码...

}

 

  这样就不需要管pval什么时候被释放,当不使用的时候,智能指针会自动调用自身的析构函数释放对象,
不要多个智能指针指向同一个对象,这可能导致一个对象被多次释放,所以当使用auto_ptr的复制构造或者
赋值操作符函数时,自身要释放对对象的所以控制权,转交给新的智能指针

void fun()
{
  int *i = new int(0);
  auto_ptr<int> ptr_1(i);
  auto_ptr<int> ptr_2 = ptr_1; //可以auto_ptr<int> ptr_2(ptr_1) ,ptr_1交出对指针i的控制权给ptr_2;
  //这样后不能再使用ptr_1,因为它已经失去对变量 i的控制
}

 

auto_ptr不能用于数组指针,因为auto_ptr调用是delete,而不是delete[],也不能用于STL

3.引用计数型智能指针shared_ptr
通过跟踪对象,记录对象的引用次数,当次数为0时才释放内存,与auto_ptr不同的是,shared_ptr可以进行多次复制行为
并且原来的指针不交出对对象控制的权限

int *i = new int(0);
std::tr1::shared_ptr<int> p1(i);
std::tr1::shared_ptr<int> p2(p1); //p1还可以使用
std::tr1::shared_ptr<int> p3 = p2; //p2还可以使用


4.这节重点不是auto_ptr和shared_ptr,而是用这两个资源管理类创建一个对象对动态分配的资源管理,实现自动释放资源,
避免忘记释放动态分配的内存而造成内存泄露

转载于:https://www.cnblogs.com/bizhu/archive/2012/07/30/2615274.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值