为什么有些浮点数显示为尾随 0

2022-09-02 10:38:22

有谁知道为什么数字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);
}

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

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

答案 1

这在 Java 1.3 - Java 6 中被确定为一个错误:http://bugs.java.com/view_bug.do?bug_id=4428022

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

事实证明,这是一个一个不合时宜的错误。(修复程序将 <= 更改为 <)。


答案 2

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