我对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();
提前感谢您的时间。
答案 0 :(得分: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)
$