php浮點(diǎn)相減不等于0
php浮點(diǎn)相減不等于0是因?yàn)橛?jì)算機(jī)將10進(jìn)制數(shù)轉(zhuǎn)為2進(jìn)制數(shù)時(shí)造成了精度丟失,因此可以使用bcadd() 函數(shù)來對浮點(diǎn)數(shù)相加減并進(jìn)行精度轉(zhuǎn)換。
另外,判斷浮點(diǎn)數(shù)是不是等于0,不是用$num == 0,而是abs($d) < EPS,這個(gè)EPS是個(gè)很小的值。
作為浮點(diǎn)型數(shù)據(jù),其精度已經(jīng)損失了一部分,達(dá)不到完全精確。所以永遠(yuǎn)不要相信浮點(diǎn)數(shù)結(jié)果精確到了最后一位,也永遠(yuǎn)不要比較兩個(gè)浮點(diǎn)數(shù)是否相等。需要說明的是,這不是PHP的問題,而是計(jì)算機(jī)內(nèi)部處理浮點(diǎn)數(shù)的問題!在 C、JAVA 等語言中也會(huì)遇到同樣的問題。
一則浮點(diǎn)數(shù)計(jì)算例子如下:
$a = 0.2+0.7; $b = 0.9; var_dump($a == $b);
打印出的結(jié)果是:bool(false)。也就是說在這里 0.2+0.7 的計(jì)算結(jié)果與 0.9 并不相等,這顯然是有違我們的常識(shí)的。
對此問題,PHP官方手冊曾又說明:顯然簡單的十進(jìn)制分?jǐn)?shù)如 0.2 不能在不丟失一點(diǎn)點(diǎn)精度的情況下轉(zhuǎn)換為內(nèi)部二進(jìn)制的格式。這和一個(gè)事實(shí)有關(guān),那就是不可能精確的用有限位數(shù)表達(dá)某些十進(jìn)制分?jǐn)?shù)。例如,十進(jìn)制的 1/3 變成了 0.3333333...。
所以要比較兩個(gè)浮點(diǎn)數(shù),需要將其控制在我們需要的精度范圍內(nèi)再行比較,因此使用 bcadd() 函數(shù)來對浮點(diǎn)數(shù)想加并進(jìn)行精度轉(zhuǎn)換(為字符串):
var_dump(bcadd(0.2,0.7,1) == 0.9); //
更多PHP相關(guān)知識(shí),請?jiān)L問PHP中文網(wǎng)!
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com