一块钱哪里去了?--java浮点型背后的故事
有這樣一道智力題:三人住旅館,老板娘說30元她們付錢后進去了,老板娘想起今天是特價25元,就叫伙計拿5元還給三位顧客,可伙計藏了2元,給了她們3元,這樣她們每人得1元,就是說每人付了9元,那3*9=27,再加伙計藏的2元,等于29元,那還有1元哪里去啦?
很多人疑惑蠻久,這剩下的1塊錢到底去了哪里?我們用角色分析一下:
老板:實得到25元
伙計:實得 2元
客戶:付出3*9=27成本
27=25+2 成本和收益是平衡的。上面主要是混淆了邏輯。
但在java開發中,你的錢也許一不小心就會丟失哦,請看題!
?
public class TestFloatDouble {public static void main(String[] args) {
System.out.println(0.05f+0.01f);
System.out.println(1.0f-0.42f);
System.out.println(4.015d*100);
System.out.println(123.3d/100);
}
}
猜對話,有大獎!哈哈
0.0600000020.58000004
401.49999999999994
1.2329999999999999
我們發現在使用浮點數類型float或者double進行運算時,數據有可能會失真。是上面原因呢?
我們知道,計算機并不能識別除了二進制數據以外的任何數據。無論我們使用何種編程語言,在何種編譯環境下工作,都要先 把源程序翻譯成二進制的機器碼后才能被計算機識別。以上面提到的情況為例,我們來驗證一下
public class TestFloatDouble {public static void main(String[] args) {
System.out.println(Float.toHexString(0.05f));
System.out.println(Float.toHexString(0.01f));
System.out.println(Float.toHexString(1.0f));
System.out.println(Float.toHexString(0.42f));
System.out.println(Double.toHexString(4.015d));
System.out.println(Double.toHexString(123.3d));
System.out.println(0.05f+0.01f);
System.out.println(1.0f-0.42f);
System.out.println(4.015d*100);
System.out.println(123.3d/100);
}
}
其結果為:
0x1.47ae14p-70x1.0p0
0x1.ae147ap-2
0x1.00f5c28f5c28fp2
0x1.ed33333333333p6
0.060000002
0.58000004
401.49999999999994
1.2329999999999999
其中:ox表示十六進制
p表示指數,其基數是2
應該是不難理解的。
?
總之, 在需要精確答案的地方,要避免使用float 和double;對于貨幣計算,要使用int、long 或BigDecimal。
參考資料:
【1】https://blog.csdn.net/aya19880214/article/details/45891581
轉載于:https://www.cnblogs.com/davidwang456/p/11442177.html
總結
以上是生活随笔為你收集整理的一块钱哪里去了?--java浮点型背后的故事的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 菜鸟、普通、老鸟程序猿如何写奇数判断?-
- 下一篇: tomcat架构分析(概览)【转】