如何在没有不必要的小数0的情况下很好地格式化浮点数为字符串?64位双倍可以表示整数+/-2。53一点儿没错考虑到这个事实,我选择对所有类型使用双类型作为单一类型,因为我的最大整数是无符号32位。但是现在我必须打印这些伪整数,但问题是它们也和实际的双数混合在一起。那么,如何在Java中很好地打印这些双打呢?我试过了String.format("%f", value),这是接近的,除了我得到很多尾随零的小值。的示例输出%f232.00000000
0.18000000000
1237875192.0
4.5800000000
0.00000000
1.23450000我想要的是:232
0.18
1237875192
4.58
0
1.2345当然,我可以编写一个函数来修剪那些零,但这是由于字符串操作而导致的大量性能损失。我能用另一个格式代码做得更好吗?编辑汤姆E.和杰里米S.的答案是不可接受的,因为他们都武断地把数字圈到小数点2位回答前请先理解问题。编辑2请注意String.format(format, args...)是区域依赖性(见下文答复)。
3 回答
12345678_0001
TA贡献1802条经验 获得超5个赞
如果这样做的目的是打印存储为双倍的整数,就像它们是整数一样,然后以最小的必要精度打印双数:
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
并且不依赖于字符串操作。
添加回答
举报
0/150
提交
取消