How can I handle precision error with float in Java?(如何在Java中使用Float处理精度错误?)
问题描述
我想知道在Java中修复精度错误的最佳方法是什么。正如您在以下示例中看到的,存在精度错误:
class FloatTest
{
public static void main(String[] args)
{
Float number1 = 1.89f;
for(int i = 11; i < 800; i*=2)
{
System.out.println("loop value: " + i);
System.out.println(i*number1);
System.out.println("");
}
}
}
显示结果为:
另外,如果有人能解释为什么它只从11开始,并且每次值都加倍。我认为所有其他值(或至少其中许多值)都显示了正确的结果。循环值:11
20.789999
循环值:22
41.579998
循环值:44
83.159996
循环值:88
166.31999
循环值:176
332.63998
循环值:352
665.27997
循环值:704
1330.5599
此类问题过去一直让我头疼,我通常使用数字格式化程序或将其放入字符串中。
编辑:正如大家所说,我可以使用双精度,但尝试之后,似乎1.89作为双精度乘792仍然会输出错误(输出是1496.8799999999999)。
我想我会尝试其他解决方案,如BigDecimal
推荐答案
如果您确实关心精度,则应该使用BigDecimal
https://docs.oracle.com/javase/8/docs/api/java/math/BigDecimal.html
https://docs.oracle.com/en/java/javase/11/docs/api/java.base/java/math/BigDecimal.html
这篇关于如何在Java中使用Float处理精度错误?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何在Java中使用Float处理精度错误?
![](/xwassets/images/pre.png)
![](/xwassets/images/next.png)
- 在 Java 中,如何将 String 转换为 char 或将 char 转换 2022-01-01
- 未找到/usr/local/lib 中的库 2022-01-01
- 将 Java Swing 桌面应用程序国际化的最佳实践是什么? 2022-01-01
- GC_FOR_ALLOC 是否更“严重"?在调查内存使用情况时? 2022-01-01
- 转换 ldap 日期 2022-01-01
- java.lang.IllegalStateException:Bean 名称“类别"的 BindingResult 和普通目标对象都不能用作请求属性 2022-01-01
- Eclipse 的最佳 XML 编辑器 2022-01-01
- 如何使 JFrame 背景和 JPanel 透明且仅显示图像 2022-01-01
- 如何指定 CORS 的响应标头? 2022-01-01
- 获取数字的最后一位 2022-01-01