如何将浮动数字的格式很好地格式化为字符串,而无需不必要的小数0

2022-08-31 04:16:06

64 位双精度值可以精确地表示整数 +/- 253

鉴于这一事实,我选择使用双精度类型作为所有类型的单一类型,因为我的最大整数是无符号的32位数字。

但是现在我必须打印这些伪整数,但问题是它们也与实际的双精度混合在一起。

那么,如何在Java中很好地打印这些双打呢?

我已经尝试过 ,这很接近,除了我得到很多小值的尾随零。String.format("%f", value)

下面是 的示例输出%f

232.00000000
0.18000000000
1237875192.0
4.5800000000
0.00000000
1.23450000

我想要的是:

232
0.18
1237875192
4.58
0
1.2345

当然,我可以编写一个函数来修剪这些零,但由于字符串操作,这会造成很大的性能损失。我可以更好地使用其他格式代码吗?


Tom E.和Jeremy S.的答案是不可接受的,因为他们都任意舍入到小数点后两位。在回答之前,请先了解问题。


请注意,这与区域设置有关(请参阅下面的答案)。String.format(format, args...)


答案 1

如果这个想法是打印存储为双精度的整数,就好像它们是整数一样,否则以最小的必要精度打印双精度:

public static String fmt(double d)
{
    if(d == (long) d)
        return String.format("%d",(long)d);
    else
        return String.format("%s",d);
}

生产:

232
0.18
1237875192
4.58
0
1.2345

并且不依赖于字符串操作。


答案 2
String.format("%.2f", value);