【问题标题】:Why do Double.parseDouble(null) and Integer.parseInt(null) throw different exceptions?为什么 Double.parseDouble(null) 和 Integer.parseInt(null) 会抛出不同的异常?
【发布时间】:2013-04-25 20:17:26
【问题描述】:

为什么 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

【问题讨论】:

  • 查看各个方法的源代码,似乎只是不一致。 parseDouble 不做空检查,遇到时只是抛出 NPE,但在 parseInt 中,则检查输入字符串是否为 null。我看不出他们应该表现不同的任何充分理由。
  • 我检查过它们是否抛出了相同的NumberFormatException。

标签: java exception nullpointerexception numberformatexception


【解决方案1】:

预期 null 会引发相同的异常是合理的;但是,这些 api 非常旧,目前可能无法更改。

还有:

由于异常行为是长期存在的并在 JavaDoc 中指定,此时更改任一方法的行为是不切实际的。关闭为不会修复。

来自:Bug Report: Integer.parseInt() and Double.parseDouble() throw different exceptions on null.

正如其他人所说:它可能由不同的作者制作。

【讨论】:

  • 相关且有趣的错误报告:bugs.sun.com/view_bug.do?bug_id=6463998 似乎在 Java 6 中,来自 Double/Float 类的 parse 方法会抛出 NPE。
  • 有趣的是,评论说这个功能在当时“非常陈旧”,现在已经是 15 年前了。
  • 这种不一致很可能源于 Java 1.0。不幸的是,很难验证这一点。我不认为 Java 1.0 可供下载,您需要一个 Windows 95 / NT 机器来运行它。或者是一台古老的 SPARC 机器。)
【解决方案2】:

注意:本文中的所有内容都在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");
}

我猜有两个不同的作者。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2022-01-15
    • 1970-01-01
    • 1970-01-01
    • 2017-03-14
    • 1970-01-01
    • 2011-03-09
    • 2022-07-22
    相关资源
    最近更新 更多