首页 > 代码库 > Effective C++ Item 29 为”异常安全”而努力是值得的
Effective C++ Item 29 为”异常安全”而努力是值得的
本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie
经验:异常安全函数即使发生异常也不会泄漏资源或允许任何数据结构败坏。这样的函数区分为三种
可能的保证:基本型-->发生异常,程序处于某个合法状态
强烈型-->发生异常,程序处于原先状态
不抛异常型-->承诺绝不抛出殿堂
示例:
class PrettyMenu{ public: //... void changeBackground(std::istream &imgSrc); //改变背景图像 //... private: Mutex mutex; //互斥器 Image *bgImage; //目前的背景图像 int imageChanges;//背景图像被改变的次数 }; void PrettyMenu::changeBackground(std::istream &imgSrc){ lock(&mutex); delte bgImage; ++imageChanges; bgImage = new Image(imgSrc); unlock(&mutex); }
解析:
泄漏资源:new Image(imgSrc) 导致异常的话,互斥器就不会 unlock
数据败坏:new Image(imgSrc) 导致异常的话,bgImage指向一个已删除的对象,imageChanges 也已被累加
纠正:
class PrettyMenu{ //... std::tr1::shared_ptr<Image> bgImage; //以对象管理资源 //... }; void PrettyMenu::changeBackground(std::istream &imgSrc){ Lock ml(&mutex); // 以对象管理资源 bgImage.reset(new Image(imgSrc)); // 以"new Image" 的执行结果设定 bgImage 内部指针 ++imageChanges; }
解析:
delte 只有 reset 函数内被使用, 而 shared_ptr::reset 函数只有在其参数被成功生成之后才会被调用。
//todo
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。