13.以对象管理资源
void f() { Investment* pInv = createInvestment(); ... delete pInv; }
- 以上代码存在问题:在delete之前出现异常,导致pInv无法删除,造成资源泄露。
- 解决方法:RAII Resource Acquisition Is Initialization 资源获取时机即初始化
使用智能指针,代码如下:
void f() { auto_ptr<Investment> pInv(createInvestment()); }
14.在资源管理类中小心copying行为
当一个RAII对象被复制,一般选择以下可能。
share_ptr允许指定删除器
- 禁止赋值
- 对底层资源进行引用计数
- 复制底层资源
- 转移底层资源拥有权
15.在资源管理类中提供对原始资源的访问
auto_ptr,share_ptr提供了get函数获取原始资源。
自定义RAII时,可以使用显示转换和隐式转换两种方式。
隐式转换:operator FontHandle() const {return f;}
16.成对使用new和delete时要采用相同的形式
new使用delete
new []使用delete []
new []的内存模型可能会是:数组个数+各个数组元素。不成对使用会引起未定义的行为。
对new []调用delete可能会引起其他对象未被析构。
typedef使用注意事项,不要定义数组
17.以独立语句将newed对象置入智能指针
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);