一、谜题
假设一个1.1元商品,客户给了2元,应该找零多少?在java 中:
System.out.println(2-1.1);预想的是输出0.9,但是实际上却是0.8999999999999999
二、解惑
问题在于1.1 这个数字不能精确的表示成为一个double(二进制浮点数),因此他被表示成最接近它double值。所以输出结果不准确。
并不是所有的小数都可以用二进制浮点数来精确表示。
三、解决方案
1.有些使用场景中,可以使用int、long代替double进行计算。
2.在要求精度比较高的计算中,建议使用BigDecimal来计算。一定要用BigDecimal(String)而不要用BigDecimal(double)。
比如 new BigDecimal(0.1) 将返回:0.1000000000000000055511151231257827021181583404541015625。
总之,在需要精确答案的地方,要避免使用float 和double。
本文探讨了在Java中1.1元商品找零问题,由于1.1不能精确表示为double导致找零结果不准确。文章解释了二进制浮点数表示小数的局限性,并提出解决方案,建议在需要精度的场景中使用int、long或BigDecimal,特别是使用BigDecimal(String)构造方法以确保精度。

3206

被折叠的 条评论
为什么被折叠?



