一般而言,一个失败的方法调用应该使对象保持“它在被调用之前的状态”。具有这种属性的方法被称为具有失败原子性。
实现的三种方法:
1 最简单的方法是设计一个非可变的对象
2一种类似的获取失败原子性的方法时,对计算处理过程调整顺序,使得任何可能失败的计算部分都发生在对象状态被修改之前。
3 编写一段恢复代码 (recovery code),由它来解释操作过程中发生的失败,以及使对象回滚到操作开始之前的状态上。这种方法主要用于永久性的数据结构。
4 在对象的临时拷贝上执行操作,当操作完成之后再把临时拷贝中的结果复制给原来的对象。
总之,作为方法规范的一部分,任何一个异常应该改变对象调用方法之前份状态。如违反该规则,则API文档应该清楚的指明对象将会处于什么样的状态