能买几颗糖??

最近这几天吃“瓜”有点多,这次我们换点糖吃。

Q:假设你有1块钱,而糖果五毛钱一颗,你买了一个,还剩多少钱?
A:必须剩五毛。(我们都是幼儿园毕业了的人)
程序实现:


能买几颗糖??_第1张图片
1.png

Q:又来买糖,兜里装了一块零一分,即(¥1.01),,糖果也涨价了,变成0.56元一个,问买一个之后兜里还剩多少钱?
A:1.01-0.56=0.45(元)(都说了幼儿园毕业了)
程序实现:


能买几颗糖??_第2张图片
2.png

WTF!!!什么鬼???
对的,你没看错,程序计算你还有0.449999999996元,为什么会这样???
假如代码欺骗了你,不要悲伤,不要心急,找出bug,解决之!

Q:闲着没事儿老想吃糖,又去买糖,这次为了方便计算,就装了一块钱,到了糖果店,货物架上摆着的糖果分别一毛一个,两毛一个,三毛一个······一样买一个的话最多能买几个?
A:都说了劳资是上过幼儿园的,当然从最便宜的买,0.1+0.2+0.3+0.4=1(元)刚好花完回家。
程序实现:


能买几颗糖??_第3张图片
3.png

WTF!!!
竟然才买三个,为啥最后钱不够了???

摘自网络的一段:
float和double的精度是由尾数的位数来决定的。浮点数在内存中是按科学计数法来存储的,其整数部分始终是一个隐含着的“1”,由于它是不变的,故不能对精度造成影响。
float:2^23 = 8388608,一共七位,由于最左为1的一位省略了,这意味着最多能表示8位数: 2*8388608 = 16777216 。有8位有效数字,但绝对能保证的为7位,也即float的精度为7~8位有效数字;
double:2^52 = 4503599627370496,一共16位,同理,double的精度为16~17位。

因此,上面的糖果问题就是double搞的鬼,同样在《effictive java》中,精度丢失也被列为78条规则中的一条,那就是如果对精度要求较高特别是涉及money的时候,一定不要使用float和double。

Q:既然不能使用double,那该用什么来解决买糖果的问题?
A:如果数字可能会比较大,可以使用BigDecimal;如果金额较小,确保不会超过int大小的话使用int也可以(单位为分即可)
代码实现如下:


能买几颗糖??_第4张图片
4.png

你可能感兴趣的:(能买几颗糖??)