64 位双精度数可以精确表示整数 +/- 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...)
_依赖于区域设置_(请参阅下面的答案)。
原文由 Pyrolistical 发布,翻译遵循 CC BY-SA 4.0 许可协议
如果想法是打印存储为双精度的整数,就好像它们是整数一样,否则以最小必要精度打印双精度:
生产:
并且不依赖于字符串操作。