1. 即使当异常被抛出时,异常安全的函数不会泄露资源,也不允许数据结构被恶化。这样的函数提供基本的,强力的,或者不抛出保证。
问题代码:
修改后:
2. 强力保证经常可以通过 copy-and-swap 被实现,但是强力保证并非对所有函数都可用。
"copy and swap"策略:它的原理很简单。先做出一个你要改变的对象的拷贝,然后在这个拷贝上做出全部所需的改变。如果改变过程中的某些操作抛出了异常,最初的对象保持不变。在所有的改变完全成功之后,将被改变的对象和最初的对象在一个不会抛出异常的操作中进行交换。
3. 一个函数通常能提供的保证不会强于他所调用的函数中最弱的保证。