浮点数 字符串 java_Java如何将浮点数转换为字符串

博客探讨了Java中浮点数(float)转换为BigDecimal时出现的精度问题。内容指出,浮点数1.15在内部表示为1.14999997615814208984375,当转换为字符串输出时,进行了舍入。博主询问了浮点数转换为字符串时舍入的具体规则,并讨论了Java/IEEE754浮点数转换的精度保证。问题聚焦于浮点数到字符串转换的准确性以及超过一定精度后的舍入行为。
摘要由CSDN通过智能技术生成

这是我正在看的东西:

float p=1.15f;

BigDecimal bdp=new BigDecimal(p);

float q=1.1499999f;

float r=1.14999999f;

System.out.println(p); //1.15

System.out.println(bdp); //1.14999997615814208984375

System.out.println(q); //1.1499999

System.out.println(r); //1.15

所以我理解“p”1.15的十进制值不能用二进制表示.

所以大的十进制“bdp”输出对我来说很有意义……这就是浮点数的实际值.

问题1

当浮点“p”转换回字符串以进行输出时(如1.15),舍入的方式/位置(从内部1.149..375到1.15)?

它在文档中指定了哪里? toString javadoc并没有真正的帮助(至少我).

The elements of the types float and double are those values that can

be represented using the IEEE 754 32-bit single-precision and 64-bit

double-precision binary floating-point formats, respectively.

This gives from 6 to 9 significant decimal digits precision (if a

decimal string with at most 6 significant decimal is converted to IEEE

754 single precision and then converted back to the same number of

significant decimal, then the final string should match the original;

问题2

所以这似乎是Java / IEEE 754浮点数应该如何工作?

我保证浮点/字符串转换/表示的准确性达到一定数量的数字(如“p”和“q”),如果超过这个数字,Java将进行一些舍入显示(如“r”) “)?

感谢帮助.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值