20

有谁知道为什么数字 0.001 到 0.009 被渲染为带有尾随 0 的字符串,但其他数字却没有。例如,数字 0.01 到 0.09 没有。

System.out.println(Locale.getDefault());
for (int i = 0; i <= 20; i++)
    System.out.println(i / 1e3);

印刷

en_GB
0.0
0.0010
0.0020
0.0030
0.0040
0.0050
0.0060
0.0070
0.0080
0.0090
0.01
0.011
0.012
0.013
0.014
0.015
0.016
0.017
0.018
0.019
0.02

编辑 DecimalFormat 的代码似乎不依赖于语言环境。如果我跑

for (Locale l : Locale.getAvailableLocales())   {
    Locale.setDefault(l);
    System.out.println(l + " " + 1 / 1e3);
}

在 Ubuntu 11.04 上的 Java 6 更新 26 我得到

ja_JP 0.0010
es_PE 0.0010
en 0.0010
... many locales with the same result ...
sv_SE 0.0010
da_DK 0.0010
es_HN 0.0010

在我得到的同一系统上的 Java 7 上

ms_MY 0.001
ar_QA 0.001
is_IS 0.001
... many locales with the same result ...
el_CY 0.001
hu 0.001
fr_FR 0.001
4

2 回答 2

13

这被确定为 Java 1.3 - Java 6 中的错误: http ://bugs.java.com/view_bug.do?bug_id=4428022 ‎</p>

编辑:至于为什么会发生这种情况,这里是从 OpenJDK 6 移植的错误报告中提到的修复:http: //hg.openjdk.java.net/jdk6/jdk6/jdk/rev/8159687b6316

事实证明这是一个错误的错误。(修复将 <= 更改为 <)。

于 2011-09-27T05:53:01.770 回答
4

对于那些感兴趣的人,这里是负责创建双精度字符串表示的 FloatingDecimal 类之间的差异。从差异中可以看出,补丁修复了 dtoa() 方法中指数为 -3 时遇到的特殊情况。

于 2011-09-27T06:23:33.933 回答