[英]Unexpected result of java calculation
为什么以下代码:
System.out.println((int)(19.99 * 100));
产生结果“1998”?
舍入错误。 如果你在没有演员表的情况下查看计算结果,你会得到:
1998.9999999999998
因此当你转换为int时,小数部分被删除,而不是向上舍入,你得到1998。
道德是,如果你需要一个确切的答案,不要使用float / double。 如果你正在谈论像money这样的离散值,请使用int并处理原子单位(例如pence。)如果你确实需要精确的小数,那么BigDecimal
就是你的朋友。
虽然你可以使用Math.round()
将结果提交到预期的位置,但这并不适用于所有情况,也无法解决潜在的问题。
那是因为19.99无法准确表示。
System.out.println(new BigDecimal(19.99));
打印实际代表的值,它最接近19.99。
19.989999999999998436805981327779591083526611328125
和19.99 * 100
是
System.out.println(new BigDecimal(19.99 * 100));
是的
1998.999999999999772626324556767940521240234375
问题是你在19.99中有一个表示错误,当它乘以100时仍然存在,你会得到一个稍微过小的数字。
如果你乘以100并向下舍入 ,那么你应该期望获得1998年的(int)
。
另一种选择是
System.out.println(Math.round(19.99 * 100));
因为19.99 * 100的计算将导致1998.999999并且你将它转换为int它将丢弃它的小数部分。
这是由于四舍五入的问题。 double
和float
很容易出现这些问题,这就是为什么建议你使用BigDecimal
类。
此代码应打印预期的内容:
BigDecimal bg = new BigDecimal("19.99");
System.out.println(bg.multiply(new BigDecimal("10")));
这会产生:
199.90
System.out.println((19.99 * 100));
通过添加int cast生成结果1998.9999999999998,它截断小数部分并返回1998
浮点数据类型(Java中的float和double)只能近似表示大多数十进制值。 有关详细信息,请参阅Joshua Bloch关于此主题的智慧语言。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.