条款13 以对象管理资源
void f()
{
Investment * pInv =creatTnvestment();
.....
delete pInv; //释放 pInv所指对象
}
两种情况导致f()不能删除它得自creatTnvestment()的对象:
1”......“区域内一个过早的return语句
2.”......“区域内的语句抛出异常
以上两种情况,delete被略过去,泄露内存
为此:把资源放进对象内,依赖C++的析构函数自动调用机制确保资源释放
auto_ptr 智能指针:其析构函数自动对其所指对象调用delete
void f()
{
std::auto_ptr<Investment> pInv(creatInvestment());
}
获得资源后立刻放进对象管理对象运用析构函数确保资源释放
注意:auto_ptr被销毁时会自动删除它所指之物,所以不能让多个auto_ptr指向同一对象,因为那样会导致对象被删除多次
为此,auto_ptr若通过复制构造或赋值操作,它们本身就会变成null,而复制所得到的指针将取得资源的唯一拥有权
此种复制不能用于STL容器
tr1::shared_ptr:引用计数型智能指针
持续追踪共有多少对象指向某个资源,并在无人指向它时自动删除该资源
复制正常,可以用于STL容器
注意:auto_ptr和tr1::shared_ptr都在其析构内执行delete,而不是delete []
即,在动态分配的数组上使用这两个指针,并不是好主意