请看下面一段代码
{
object *p = new object();
...
delete p;
}
如果在执行delete这行代码之前该片段产生异常,程序会在发生异常点停止并产生栈展开,所以不会执行delete语句,造成资源泄漏。解决的方法如下
{
share_ptr p(new object());
...
}
用智能指针替代普通指针,当发生异常并进行栈展开过程时,程序会析构已经构造完毕的类,从而避免了资源泄漏。上面运用的是共享指针,但可以根据实际需求决定使用共享指针或独占指针。
再请看下面一段代码
object makeObject()
{
return new object();
}
{
object *p=makeObject();
...
}
由于申请资源和使用资源不在同一个代码区,很有可能造成我们忘记释放资源,因为该资源并不是由我们申请的。当然可以用智能指针解决该问题,但是还有另外一种更加灵活的办法。
class manager{
public:
manager(object *tt):p(tt){
}
~manager(){
delete p;
}
object *p;
};
{
manager target(makeObject());
...
}
在构造函数中负责接管该资源,在析构函数中负责释放该资源。