int priority();
void processWidget(std::tr1::shared_ptr<Widget> pw,int priority);
调用processWidget:
processWidget(new Widget,priority());
它不能通过编译。tr1::shared_ptr构造函数需要一个原始指针,但该构造函数是个explict构造函数,无法进行隐式转换,将得自“new Widget”的原始指针转换为processWidget所要求的tr1::shared_ptr。
写成这样可以通过
processWidget(std::tr1::shared_ptr<Widget>(new Widget),priority());
编译器必须创建代码,做三件事:
1.调用priority
2.执行new Widget
3.调用tr1::shared_ptr构造函数
万一对priority的调用导致异常,“new Widget”返回的指针将会遗失,因为尚未被置入tr1::shared_ptr内,后者是期盼防卫资源泄露的武器.
std::tr1::shared_ptr<Widget> pw(new Widget);在单独语句内以智能指针存储newed所得对象
processWidget(pw,priority());//调用动作决不至于造成泄露
以独立语句将newed对象存储于(置入)智能指针内。如果不这样做,一旦异常被抛出,有可能导致难以察觉的资源泄露。