我担心这是一个运行时异常,所以应该谨慎使用它。
标准用例:
void setPercentage(int pct) {
if( pct < 0 || pct > 100) {
throw new IllegalArgumentException("bad percent");
}
}
但这似乎会迫使以下设计:
public void computeScore() throws MyPackageException {
try {
setPercentage(userInputPercent);
}
catch(IllegalArgumentException exc){
throw new MyPackageException(exc);
}
}
让它恢复为已检查的异常。
好的,但让我们开始吧。如果输入错误,则会出现运行时错误。因此,首先,这实际上是一个很难统一实施的策略,因为您可能必须进行完全相反的转换:
public void scanEmail(String emailStr, InputStream mime) {
try {
EmailAddress parsedAddress = EmailUtil.parse(emailStr);
}
catch(ParseException exc){
throw new IllegalArgumentException("bad email", exc);
}
}
更糟糕的是——虽然检查0 <= pct && pct <= 100
客户端代码可能是静态的,但对于更高级的数据(例如电子邮件地址)而言并非如此,或者更糟糕的是,必须针对数据库进行检查,因此通常客户端代码不能预先证实。
所以基本上我要说的是我没有看到一个有意义的一致政策来使用IllegalArgumentException
. 似乎不应该使用它,我们应该坚持我们自己的检查异常。抛出这个的好用例是什么?