void f() { Investment* pInv = createInvestment(); ... delete pInv; }
使用智能指针,代码如下:
void f() { auto_ptr<Investment> pInv(createInvestment()); }
当一个RAII对象被复制,一般选择以下可能。
share_ptr允许指定删除器
- 禁止赋值
- 对底层资源进行引用计数
- 复制底层资源
- 转移底层资源拥有权
auto_ptr,share_ptr提供了get函数获取原始资源。
自定义RAII时,可以使用显示转换和隐式转换两种方式。
隐式转换:operator FontHandle() const {return f;}
new使用delete
new []使用delete []
new []的内存模型可能会是:数组个数+各个数组元素。不成对使用会引起未定义的行为。
对new []调用delete可能会引起其他对象未被析构。
typedef使用注意事项,不要定义数组
int priority(); void processWidget(shared_ptr<Widget> pw, int priority); processWidget(shrare_ptr<Widget>(new Widget), priority());
以上代码问题如下:
可能的执行顺序有
执行new Widget
调用priority
调用share_ptr
如果priority调用异常,导致new Widget资源泄露。
解决方法如下:
share_ptr<Widget> pw(new Widget); processWidget(pw, priority);
原文地址:http://blog.csdn.net/zjufirefly/article/details/44341175