小编典典

如何在没有不必要的十进制 0 的情况下很好地将浮点数格式化为字符串

all

一个 64 位的 double 可以精确地表示整数 +/- 2 53。

鉴于这一事实,我选择使用双精度类型作为我所有类型的单一类型,因为我的最大整数是一个无符号的 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...)取决于 _ 语言环境_ (请参阅下面的答案)。


阅读 78

收藏
2022-03-08

共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

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

2022-03-08