为什么Double.parseDouble(null)和Integer.parseInt(null)抛出不同的异常?


92

为什么Double.parseDouble(null)和Integer.parseInt(null)抛出不同的异常?

这是历史性事故还是故意的?该文档明确指出了的两种类型的异常Double.parseDouble(...)和的一种类型Integer.parseInt(),但似乎不一致:

Integer.parseInt(null); // throws java.lang.NumberFormatException: null

然而

Double.parseDouble(null); // throws java.lang.NullPointerException


2
检查各个方法的源代码,似乎只是一个不一致。parseDouble不会执行null检查,只会在遇到NPE时抛出NPE,但是在中parseInt,则检查输入字符串null。我看不出它们应该表现出什么不同的充分理由。
NilsH

我检查了它们是否抛出了sameNumberFormatException。
twlkyao '16

Answers:


67

可以期望为null抛出相同的异常,这是合理的。但是,这些api很旧,因此此时可能无法更改。

和:

由于异常行为是长期存在的,并且已在JavaDoc中指定,因此此时更改任一方法的行为都是不切实际的。关闭将无法解决。

摘自:错误报告:Integer.parseInt()和Double.parseDouble()在null上引发不同的异常。

就像其他人所说的:它可能是由不同的作者完成的。


2
相关且有趣的错误报告:bugs.sun.com/view_bug.do?bug_id=6463998好像在Java 6中一样,Double / Float类的parse方法抛出NPE。
nhahtdh

2
有趣的是,该评论说该功能当时“非常古老” 而现在已经是15年前了。
南爪野兔

这种不一致很可能起源于Java 1.0。不幸的是,很难验证这一点。我认为没有Java 1.0可供下载,您需要Windows 95 / NT机器才能运行它。或一台古老的SPARC机器。)
Stephen C,

59

注意:本文中的所有内容均来自Java7-b147的源代码

Double.parseDouble()进入Sun库(在中sun.misc.FloatingDecimal),首先发生的重要事情是:

in = in.trim(); // don't fool around with white space.
                // throws NullPointerException if null

Integer.parseInt()Integer课程中手动完成。发生的第一件事是:

if (s == null) {
    throw new NumberFormatException("null");
}

我猜想有两个不同的作者。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.