Effective C++学习笔记总链接
改善程序与设计的55个具体做法学习笔记-每日1条
条款17:以独立语句将newed对象置入智能指针
【技巧】
以独立语句将newed对象存储于(置入)智能指针内,一旦异常被抛出,有可能导致难以察觉的资源泄漏。
看下面程序:
int priority();
void processWidget(std::shared_ptr<Widget> pw, int priority);
如何调用processWidget?
processWidget(new Widget, priority()); //error
上述调用不能通过编译。
原因: 不存在widget* 转换为std::shared_ptr的构造函数
shared_ptr构造函数需要一个原始指针(raw pointer),但该构造函数是个explicit构造函数,无法进行隐式转换。需要强转:
processWidget(std::shared_ptr<Widget>(new Widget), priority());
上述代码问题
但上述调用时有问题,由于调用形参次序不定,可能出现资源泄漏。
在调用processWidget之前,会做三件事:
- 执行“new Widget”
- 调用std::shared_ptr构造函数
- 调用 priority()
但是调用priority()的顺序可能排在第一或第二或第三。
或许priority()的调用导致异常,可能导致new Widget返回的指针将会遗失,使它尚未被置入std::shared_ptr(用来防卫资源泄漏的武器)内。
正确做法
避免上述问题的做法是:使用分离语句
std::shared_ptr<Widget> pw(new Widget); // 在单独语句内以智能指针存储new所得对象
processWidget(pw, priority()); // 这个调用绝不会造成资源泄漏
将它们分隔开,位于不同语句内,编译器不得在它们之间任意选择执行次序。