避免引发新的异常
时间:2020-03-06 14:55:06 来源:igfitidea点击:
我有一个if条件,用于检查值,它会引发新的NumberFormatException
还有其他编码方式吗
if (foo) { throw new NumberFormatException } // .. catch (NumberFormatException exc) { // some msg... }
解决方案
如果目的是避免引发新的异常:
if(foo) { //some msg... } else { //do something else }
在Java中,我们可以先尝试使用正则表达式解析字符串,然后再尝试将其转换为数字。
如果我们尝试捕获自己的异常(为什么?),则可以执行以下操作:
try { if (foo) throw new NumberFormatException(); } catch(NumberFormatexception) {/* ... */}
如果我们正在执行以下操作:
try { // some stuff if (foo) { throw new NumberFormatException(); } } catch (NumberFormatException exc) { do something; }
然后,可以肯定的是,我们可以完全避免该异常,并在条件块内执行"执行操作"部分。
如果尝试用其他错误处理机制替换引发异常,则唯一的选择是返回或者设置错误代码,问题是我们必须去确保已在其他地方检查了该错误。
例外是最好的。
如果可以以其他更优雅的方式处理异常,请不要抛出异常。异常的代价很高,仅应用于无法控制的情况(例如,数据库服务器没有响应)。
如果要确保设置了值并正确设置了格式,则应尝试以更合理的方式处理这些条件的失败。例如...
if(myObject.value != null && Checkformat(myObject.Value) { // good to go } else { // not a good place to be. Prompt the user rather than raise an exception? }
如果我们知道将导致我们引发NumberFormatException的流程,请使用代码来处理这种情况。我们不应将"异常"层次结构用作程序流机制。