PHP浮點數比較不准

2021-08-30 19:04:38 字數 633 閱讀 5342

首先看一段**:

<?php

$a = 0.1;

$b = 0.7;

var_dump(($a + $b) == 0.8);

列印出來的值居然為 boolean false

這是為啥?php手冊對於浮點數有以下警告資訊:

warning

浮點數精度

顯然簡單的十進位制分數如同 0.1 或 0.7 不能在不丟失一點點精度的情況下轉換為內部二進位制的格式。這就會造成混亂的結果:例如,floor((0.1+0.7)*10) 通常會返回 7 而不是預期中的 8,因為該結果內部的表示其實是類似 7.9999999999...。

這和乙個事實有關,那就是不可能精確的用有限位數表達某些十進位制分數。例如,十進位制的 1/3 變成了 0.3333333. . .。

所以永遠不要相信浮點數結果精確到了最後一位,也永遠不要比較兩個浮點數是否相等。如果確實需要更高的精度,應該使用任意精度數學函式或者 gmp 函式

那麼上面的算式我們應該改寫為

<?php

$a = 0.1;

$b = 0.7;

var_dump(bcadd($a,$b,2) == 0.8);

這樣就能解決浮點數的計算問題了

php比較浮點數

php手冊中有一句話,永遠不要比較兩個浮點數是否相等,但是在實際情況中,有時候還是會涉及到關於浮點數的運算和比較,當出現這種情況下,請使用bc math擴充套件函式或者gmp 函式。我們來看一種常見的情況 a 1.3 b 1.2 c 0.1 d a b if d c else printf 20f ...

php 浮點數比較方法

首先看乙個例子 a 0.1 b 0.9 c 1 var dump a b c var dump c b a a b c 返回true,正確 c b a 返回false,錯誤 為什麼會這樣呢?運算後,精度為20位時實際返回的內容如下 a 0.1 b 0.9 c 1 printf 20f a b 1.0...

浮點數比較

在數 算當中經常會涉及到判斷兩個數是否相等的情況 對於整數很好處理 a b這樣的乙個語句就可以解決全部的問題 但是對於浮點數是不同的 首先,浮點數在計算機當中的二進位制表達方式就決定了大多數浮點數都是無法精確的表達的 現在的計算機大部分都是數字計算機,不是模擬機,數字機的離散化的資料表示方法自然無法...