所谓失败的原子性,就是在一个方法失败之后,使对象保持“它在被调用之前的状态”。因为,尤其是CheckedException发生后,一般是希望程序可以从异常中恢复过来的。
那么如何才能保持对象的状态呢?最简单的方法就是使用非可变类型的对象(见【第13条】)。因为无论什么时候,非可变类的状态都是不可改变的。
对于可变对象,常见的方法是在对其进行处理之前,先做参数有效性的检查(见【第23条】),如果参数有问题,马上就先抛出一个异常。这时候对象的状态还未改变。
另一种方法是,将处理的过程调整一下顺序,让可能抛出异常的处理写在前面,而会改变对象状态的处理写在后面。
还有一种不太常用的方法,是编写一段恢复代码,发生失败时,可以使对象回滚到操作开始之前的状态。
最后一种方法是,在对象的一份临时拷贝上执行操作,当操作正确结束后,再把临时拷贝中的结果复制给原来的对象。如果一旦失败,不进行这个复制,也就保持了原对象的状态。
总之,作为方法规范的一部分,任何一个异常都不应该改变对象调用该方法之前的状态。
【Effective Java 学习笔记】系列连载专题请见:
http://tonylian.iteye.com/categories/64208