php浮點相減不等于0

php浮點相減不等于0

php浮點相減不等于0是因為計算機將10進制數轉為2進制數時造成了精度丟失,因此可以使用bcadd() 函數來對浮點數相加減并進行精度轉換。

另外,判斷浮點數是不是等于0,不是用$num == 0,而是abs($d) < EPS,這個EPS是個很小的值。

作為浮點型數據,其精度已經損失了一部分,達不到完全精確。所以永遠不要相信浮點數結果精確到了最后一位,也永遠不要比較兩個浮點數是否相等。需要說明的是,這不是PHP的問題,而是計算機內部處理浮點數的問題!在 C、JAVA 等語言中也會遇到同樣的問題。

一則浮點數計算例子如下:

$a = 0.2+0.7;$b = 0.9;var_dump($a == $b);

打印出的結果是:bool(false)。也就是說在這里 0.2+0.7 的計算結果與 0.9 并不相等,這顯然是有違我們的常識的。

對此問題,PHP官方手冊曾又說明:顯然簡單的十進制分數如 0.2 不能在不丟失一點點精度的情況下轉換為內部二進制的格式。這和一個事實有關,那就是不可能精確的用有限位數表達某些十進制分數。例如,十進制的 1/3 變成了 0.3333333...。

所以要比較兩個浮點數,需要將其控制在我們需要的精度范圍內再行比較,因此使用 bcadd() 函數來對浮點數想加并進行精度轉換(為字符串):

var_dump(bcadd(0.2,0.7,1) == 0.9); // 輸出:bool(true)

更多PHP相關知識,請訪問龍方網絡!

以上就是php浮點相減不等于0的詳細內容,更多請關注龍方網絡其它相關文章!

鄭重聲明:本文版權包含圖片歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們([email protected])修改或刪除,多謝。

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

留言與評論(共有 0 條評論)
   
驗證碼:
彩票店