如何避免Java中浮點(diǎn)數(shù)或雙精度的浮點(diǎn)精度錯(cuò)誤?我有一個(gè)非常惱人的問(wèn)題,長(zhǎng)數(shù)量的浮動(dòng)或雙倍在Java中?;旧希业南敕ㄊ?,如果我執(zhí)行:for ( float value = 0.0f; value < 1.0f; value += 0.1f ) System.out.println( value );我得到的是:0.00.10.20.30.40.50.60.700000050.80000010.9000001我知道有一個(gè)累積的浮動(dòng)精度誤差,但是,如何擺脫這一點(diǎn)?我試著用雙倍來(lái)減少錯(cuò)誤的一半,但結(jié)果仍然是一樣的。有什么想法嗎?
3 回答

眼眸繁星
TA貢獻(xiàn)1873條經(jīng)驗(yàn) 獲得超9個(gè)贊
BigDecimal
. float
double
BigDecimal
double
BigDecimal
添加回答
舉報(bào)
0/150
提交
取消