首頁 >後端開發 >php教程 >為什麼 PHP 中的浮點比較有時會失敗,我們該如何正確地比較它們?

為什麼 PHP 中的浮點比較有時會失敗,我們該如何正確地比較它們?

DDD
DDD原創
2024-12-23 16:56:11704瀏覽

Why Do Floating-Point Comparisons in PHP Sometimes Fail, and How Can We Correctly Compare Them?

比較 PHP 中的浮點數

比較 PHP 中的浮點數時,必須處理它們的表示形式和精度方面的細微差異。這可能具有挑戰性,如以下程式碼所示:

<?php
$a = 0.17;
$b = 1 - 0.83; // 0.17

if ($a == $b) {
    echo 'a and b are same';
} else {
    echo 'a and b are not same';
}
?>

在此程式碼中,您可能會期望 if 條件為 true,因為 $a 和 $b 表示相同的值。然而,它的計算結果意外地為 false,表示 $a 和 $b 不相等。

為什麼比較失敗

造成這種差異的原因在於浮點數的內部表示在計算機中。這些數字是近似值,其精確度是有限的。執行浮點計算時,可能會累積小的捨入誤差,從而在比較它們是否相等時導致意外結果。

處理浮點比較

要解決此問題,您應該避免使用嚴格相等運算符 (==) 除非您完全確定它們代表相同的值。相反,請使用 abs() 函數,並將兩個值之間的絕對差與可接受的小容差進行比較。

例如,您可以使用以下程式碼以0.00001 的容差比較$a 和$b :

if (abs(($a - $b) / $b) < 0.00001) {
    echo "a and b are same";
} else {
    echo "a and b are not same";
}

此方法提供了一種更可靠的方法來比較實際用途的浮動。

以上是為什麼 PHP 中的浮點比較有時會失敗,我們該如何正確地比較它們?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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