2

我对 BigDecimal 有一个奇怪的问题。

我有一个解析方法如下:

protected BigDecimal parseBigDecimalFromText(String text) {
    Logger.info("parseBigDecimalFromText("+text+")");
    return new BigDecimal(text);
}

现在,当我运行测试时,代码可以正常工作。

@Test
public void parseBigDecimalFromZero() {
    Logger.createLogger();

    // given
    String text = "0";

    // when
    BigDecimal bigDecimal = basicPage.parseBigDecimalFromText(text);

    // then
    Assert.assertEquals(new BigDecimal("0"), bigDecimal);
}

但是当我通过完全相同的字符串“0”执行我的应用程序时,我得到了一个“java.lang.NumberFormatException”

以下是日志:

2014-11-05 23:21:33.142: INFO - parseBigDecimalFromText(0) 
2014-11-05 23:21:33.142: SEVERE - null 
java.lang.NumberFormatException
    at java.math.BigDecimal.<init>(BigDecimal.java:470)
    at java.math.BigDecimal.<init>(BigDecimal.java:739)
    at com.aa.travian.pages.BasicPage.parseBigDecimalFromText(BasicPage.java:121)

我知道当我的应用程序启动时,我正在设置一个特定的语言环境:

Locale locale = getConfig().getLocale();
ResourceBundle = ResourceBundle.getBundle("translations", locale);

但我不明白这应该如何破坏我的 parseBigDecimalFromText 方法。

以下是我的java版本:

java -versionjava version "1.7.0_65"
OpenJDK Runtime Environment (IcedTea 2.5.2) (7u65-2.5.2-3~14.04)
OpenJDK 64-Bit Server VM (build 24.65-b04, mixed mode)

知道这里发生了什么吗?查看 BigDecimal 源代码,它看起来像是在解析指数时下降:

// exponent expected
if ((c != 'e') && (c != 'E'))
    throw new NumberFormatException();

在此先感谢您的时间。

4

1 回答 1

2

您无法记录字符串变量来验证其内容,因为许多不同的字符串在视觉上无法区分。

相反,将所有字符串视为二进制数据。制作一个十六进制转储并进行比较。

这是重现输出和问题的一种方法:

$ cat Test.java
import java.util.regex.*;
import java.util.logging.*;
import java.math.*;

class Test {
    public static void main(String[] args) {
        Logger logger = Logger.getLogger("test");
        String text = "0\0";
        logger.info("parseBigDecimalFromText("+text+")");
        new BigDecimal(text);
    }
}

$ javac Test.java
$ java Test
Nov 06, 2014 12:55:40 AM Test main
INFO: parseBigDecimalFromText(0)
Exception in thread "main" java.lang.NumberFormatException
        at java.math.BigDecimal.<init>(BigDecimal.java:470)
        at java.math.BigDecimal.<init>(BigDecimal.java:739)
        at Test.main(Test.java:10)
$
于 2014-11-05T23:59:24.643 回答