Java程序中奇怪的浮點行為在我的程序中,我有一個具有25個雙值0.04的數組,當我試圖在循環中對這些值進行求和時,我得到以下結果:0.0 + 0.04 = 0.040.04 + 0.04 = 0.080.08 + 0.04 = 0.120.12 + 0.04 = 0.160.16 + 0.04 = 0.20.2 + 0.04 = 0.240000000000000020.24000000000000002 + 0.04 = 0.280.28 + 0.04 = 0.320.32 + 0.04 = 0.360.36 + 0.04 = 0.399999999999999970.39999999999999997 + 0.04 = 0.439999999999999950.43999999999999995 + 0.04 = 0.47999999999999990.4799999999999999 + 0.04 = 0.51999999999999990.5199999999999999 + 0.04 = 0.55999999999999990.5599999999999999 + 0.04 = 0.60.6 + 0.04 = 0.640.64 + 0.04 = 0.680.68 + 0.04 = 0.72000000000000010.7200000000000001 + 0.04 = 0.76000000000000010.7600000000000001 + 0.04 = 0.80000000000000020.8000000000000002 + 0.04 = 0.84000000000000020.8400000000000002 + 0.04 = 0.88000000000000020.8800000000000002 + 0.04 = 0.92000000000000030.9200000000000003 + 0.04 = 0.9600000000000003為什么會發生這種事?!
3 回答

浮云間
TA貢獻1829條經驗 獲得超4個贊
縮放:如果您的所有數字都是0.01的倍數(例如),那么將所有數據乘以100,并使用整數算術(這是精確的)。 數字類型:如果語言具有數字類型(類似于 numeric
輸入SQL),您可以使用它。 任意精確理據:使用bignum庫,如 ,它允許您將這些數字表示為兩個整數的比率。 小數點浮點數:如果您有十進制浮點數,如 你可以用它。
添加回答
舉報
0/150
提交
取消