Java谜题2:找零时刻

本文探讨了在Java中1.1元商品找零问题,由于1.1不能精确表示为double导致找零结果不准确。文章解释了二进制浮点数表示小数的局限性,并提出解决方案,建议在需要精度的场景中使用int、long或BigDecimal,特别是使用BigDecimal(String)构造方法以确保精度。

一、谜题

假设一个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。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值