您好,登錄后才能下訂單哦!
這篇文章主要為大家詳細介紹了PHP浮點數比較的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
PHP手冊里有一句話:永遠不要比較兩個浮點數是否相等。
計算機內部處理浮點數的方式決定了浮點數不可能100%的精確,所以在處理浮點數運算時會出現精度損失問題。比如下面這段程序:
<?php $a = 15521.42; $b = 15480.3; $c = $a-$b; var_dump($c); //php4:float(41.120000000001) php5:float(41.12) var_dump($c == 41.12); //bool(false) ?>
第一條輸出語句:在PHP4下輸出$c可能是41.120000000001,或類似的結果,后面的1就屬于精度損失的部分。在PHP5中對這個問題做了些“優化”,輸出結果中不會顯示不精確的部分,但同時也會讓我們忽視這個問題,以為$c==41.12。
第二條輸出語句:在PHP4和PHP5中都會輸出false。
聲明一點:這不是PHP的問題,而是計算機內部處理浮點數的問題!在C/JAVA中也會遇到同樣的問題。
延伸一下:我們同樣不能使用>、<、>=或<=
那么,我們應該怎么比較兩個浮點數相等呢?
看了上面的介紹后,我們就知道了:沒辦法精確的比較兩個浮點數相等!so..我們只能在我們要的精度范圍內比較(比如上面的示例,我們只需要比較$c在小數點后兩位內等于41.12即可)。
下面是PHP手冊評論中的示例
nction floatcmp($f1,$f2,$precision = 10) {// are 2 floats equal $e = pow(10,$precision); $i1 = intval($f1 * $e); $i2 = intval($f2 * $e); return ($i1 == $i2); } function floatgtr($big,$small,$precision = 10) {// is one float bigger than another $e = pow(10,$precision); $ibig = intval($big * $e); $ismall = intval($small * $e); return ($ibig > $ismall); } function floatgtre($big,$small,$precision = 10) {// is on float bigger or equal to another $e = pow(10,$precision); $ibig = intval($big * $e); $ismall = intval($small * $e); return ($ibig >= $ismall); }
關于PHP浮點數比較的方法介紹就分享到這里了,當然并不止以上和大家分析的辦法,不過小編可以保證其準確性是絕對沒問題的。希望以上內容可以對大家有一定的參考價值,可以學以致用。如果喜歡本篇文章,不妨把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。