我想知道在 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("");
}
}
}
显示的结果是:
loop value: 11
20.789999
loop value: 22
41.579998
loop value: 44
83.159996
loop value: 88
166.31999
loop value: 176
332.63998
loop value: 352
665.27997
loop value: 704
1330.5599
此外,如果有人可以解释为什么它只从 11 开始并且每次都将值加倍。我认为所有其他值(或至少其中许多值)都显示了正确的结果。
像这样的问题过去曾让我头疼,我通常使用数字格式化程序或将它们放入字符串中。
编辑: 正如人们提到的,我可以使用 double ,但在尝试之后,似乎 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 - 如何在 Java 中处理 float 的精度错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6713673/