以独立语句将newed对象置入智能指针内。如若不然,一旦异常被抛出,有可能导致难以察觉的资源泄露。
来一例:
int priority();//处理程序优先权的函数
void processWidget(std::tr1::shared_ptr<Widget> pw, int priority);//该函数在动态分配所得的Widget上进行某些带有优先权的处理。
调用:
processWidget(new Widget,priority()); //编译不过!该构造函数是explicit 无法隐式转换为shared_ptr
因此可以写成:
processWidget(std::tr1::shared_ptr<Widget>(new Widget),priority());//可以编译通过,但是...可能泄露资源。
后果:一旦发生异常,可能泄露资源。
原因:
在调用processWidget之前,编译器执行3步:
(1)调用priority()
(2)new Widget
(3)调用tr1:shared_ptr构造函数
但是c++调用顺序跟java和c#不同,不是以特定顺序完成。priority函数的调用有可能在第一、第二或者第三执行。当在第二位执行的情况下:
(1)new Widget
(2)调用priority()
(3)调用tr1:shared_ptr构造函数
如果new Widget抛异常,由于Widget尚未置入shared_ptr,指针遗失。
解决方案:使用分离语句。
std::tr1::shared_ptr<Widget> pw(new Widget);
processWidget(pw,priority());