搜尋
首頁php教程php手册PHP中浮點數計算比較及取整不準確的解決方法_php基礎

浮點數計算結果比較
一則浮點數計算範例如下:

複製程式碼 程式碼如下:

$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...。

我們將上面的變數以雙精確度格式列印出來:

複製程式碼 程式碼如下:

$a = 0.2 0.7;
$b = 0.9;
printf("%0.20f", $a);
echo '
';
printf("%0.20f", $b);

輸出結果如下:

複製程式碼 程式碼如下:

0.89999999999999991118
0.90000000000000002220

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

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

複製程式碼 程式碼如下:

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

浮點數取整

在《PHP 取整函數 ceil 與 floor》一文中,曾有例子:

複製程式碼 程式碼如下:

echo ceil(2.1/0.7);    // 輸出:4
?>

經過上面對浮點數計算的探討,知道這是浮點數計算結果不完全精確造成的:

複製程式碼 程式碼如下:

printf("%0.20f", (2.1/0.7));    // 輸出:3.00000000000000044409
?>

經過上面對浮點數計算的探討,知道這是浮點數計算結果不完全精確造成的,因此使用 round() 函數處理一下即可:

複製程式碼 程式碼如下:

echo ceil( round((2.1/0.7),1) );
?>

雖然 round() 函數是依照指定的精確度進行四捨五入,但保留小數點後一位,對我們的取整結果是沒影響的。

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),