摘要:
异常应该只用于异常的情况下,它们永远不应该用于正常的控制流。
设计良好的API不应该强迫它的客户端为了正常的控制流而使用异常。
如果对象有“状态相关的方法”。可以使用如下的两种方式来避免调用该方法时,抛出异常。
状态测试方法
使用方法来判断对象的“状态相关方法”是否可以被调用。
例如:Iterator接口的hasNext方法
i.hasNext()
可识别的返回值
返回一个可以识别的值来表示当前的对象的状态是否正常。例如在不正常的时候,返回null
状态测试方法vs可识别的返回值
状态测试方法提供了很好的可读性,对于使用不当的情形,可以更加易于检测和改正:如果忘了去调用状态测试方法,状态相关的方法就会抛出异常,使这个bug变得明显;如果忘了去检查可识别的返回值,则这个bug就很难发现。
总结:
异常是为了在异常情况下使用而设计的。不要将它们用于普通的控制流,也不要编写迫使它们这么做的API。