Robin Chow's C++ Blog

 

[导入]编写异常安全的代码

对于异常安全的评定,可分为三个级别:基本保证、强保证和不会失败。

  基本保证:确保出现异常时程序(对象)处于未知但有效的状态。所谓有效,即对象的不变式检查全部通过。
  强保证:确保操作的事务性,要么成功,程序处于目标状态,要么不发生改变。
  不会失败:对于大多数函数来说,这是很难保证的。对于C++程序,至少析构函数、释放函数和swap函数要确保不会失败,这是编写异常安全代码的基础。

总结一下编写异常安全代码的几条准则:

  1.只在应该使用异常的地方抛出异常
  2.如果不知道如何处理异常,请不要捕获(截留)异常。
  3.充分使用RAII(smart ptr),旁路异常。
  4.努力实现强保证,至少实现基本保证。
  5.确保析构函数、释放类函数和swap不会失败。

  另外,还有一些语言细节问题:

  1.不要这样抛出异常:throw new exception;这将导致内存泄漏。
  2.自定义类型,应该捕获异常的引用类型:catch(exception& e)或catch(const exception& e)。
  3.不要使用异常规范,即使是空异常规范。编译器并不保证只抛出异常规范允许的异常,更多内容请参考相关书籍。


文章来源:http://my.donews.com/robinchow/2007/01/11/vdcfhpltuhbzmtzupiknflljcnxqpkyloaqv/

posted on 2007-10-23 20:51 Robin Chow 阅读(114) 评论(0)  编辑 收藏 引用


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


导航

统计

常用链接

留言簿(1)

随笔分类

随笔档案

搜索

最新评论

阅读排行榜

评论排行榜