Effective C++ 读书笔记(17)
2013-07-12 09:15
218 查看
条款17:以独立的语句将new的资源放入到智能指针中
考虑以下情况:
我们在对processWidget函数进行调用的时候,可以采用如下形式:
注意我们不能直接将new widget作为实参传入std:shared_ptr<widget> pw形参中,在上面的函数调用中,看起来没有问题但是可
能回出现内存泄露的情况,因为在函数中,参数的调用顺序会因为编译器的不同而不同的,例如上面的循序可能是:
new widget
priority调用
std::tr1::shared_ptr<widget> 初始化
这样可能出现的问题就是当new widget成功后,如果priority()函数调用失败,由于new widget未能放入到智能指针中,但是退出的
时候资源得不到释放,解决办法就是讲实参独立出来,例如:
请记住:
要以独立的语句将资源放入到资源管理器中,否则一旦抛出异常可能出现内存泄露!
考虑以下情况:
int prirority(); void processWidget(std::shared_ptr<Widget> pw, int priority);
我们在对processWidget函数进行调用的时候,可以采用如下形式:
processWidget(std::tr1::shared_ptr<widget> pw(new widget), priority());
注意我们不能直接将new widget作为实参传入std:shared_ptr<widget> pw形参中,在上面的函数调用中,看起来没有问题但是可
能回出现内存泄露的情况,因为在函数中,参数的调用顺序会因为编译器的不同而不同的,例如上面的循序可能是:
new widget
priority调用
std::tr1::shared_ptr<widget> 初始化
这样可能出现的问题就是当new widget成功后,如果priority()函数调用失败,由于new widget未能放入到智能指针中,但是退出的
时候资源得不到释放,解决办法就是讲实参独立出来,例如:
std::tr1::shared_ptr<widget> pw(new widget); int pri = priority(); processWidget(pw,pri);
请记住:
要以独立的语句将资源放入到资源管理器中,否则一旦抛出异常可能出现内存泄露!
相关文章推荐
- 读书笔记《Effective c++》 条款17 以独立语句将newed对象置入智能指针
- 【Effective C++】读书笔记 条款13~条款17
- effective C++ 读书笔记 条款17 以独立语句讲newed对象置入智能指针
- Effective C++ 读书笔记(11-17):构造析构和赋值函数
- 读书笔记《Effective C++》条款17:以独立语句将newed对象置入智能指针
- Effective C++ 读书笔记(8)
- 读书笔记《Effective C++》条款10:令operator=返回一个reference to *this
- 读书笔记《Effective c++》 条款19 设计class犹如设计type
- Effective C++ 读书笔记(29)
- Effective C++ 读书笔记六
- Effective C++ 读书笔记(35-44):继承关系与面向对象设计
- 读书笔记《Effective C++》条款34:区分接口继承和实现继承
- 读书笔记《Effective C++》条款36:绝不重新定义继承而来的non-virtual函数
- 《Effective C++》 读书笔记(一) 让自己习惯C++
- effective C++ 读书笔记 条款07 为多态基类声明virtual析构函数
- 《Effective C++》读书笔记(三) 构造/析构/赋值运算 (第二部分)
- 《effective C++》读书笔记(一)
- 【C++】析构函数和virtual函数引发的隐晦问题 ——《Effective C++》读书笔记5
- 《Effective C++》读书笔记之item25:考虑写出一个不抛异常的swap函数
- Effective C++-读书笔记