Java中的浮点精度错误
我想知道什么是修复精度错误的最佳方法是在 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开始,并且每次都加倍价值.我认为所有其他值(或至少有很多)显示正确的结果. 像这样的问题使我头疼,我通常使用数字格式化程序或将它们放在一个字符串中. 编辑:正如人们所说,我可以使用一个double,但是在尝试之后,似乎是1.89作为双倍的792仍然输出一个错误(输出是1496.8799999999999). 我想我会尝试其他解决方案,如BigDecimal 解决方法如果你真的关心精度,你应该使用BigDecimalhttp://download.oracle.com/javase/1,5.0/docs/api/java/math/BigDecimal.html (编辑:莱芜站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- Spring类型转换 ConversionSerivce Convertor解析
- Arduino Map在Java中的等效功能
- Java SAXParser:不同于`localName`和`qName`
- Spring 报错:元素 context:component-scan 的前缀 context
- Java xml出现错误 javax.xml.transform.TransformerExcepti
- java – 在if语句中使用bitwise和里面
- java – Jackson通过删除’is’来重命名原始布尔字段
- javaweb中mysql数据库连接步骤方法及其实例
- Mybatis foreach标签使用不当导致异常的原因浅析
- 多线程 – Rust为线程或函数创建超时的正确方法是什么?