當(dāng)前位置:
首頁(yè) >
PHP下的浮点运算不准的解决办法
發(fā)布時(shí)間:2025/7/14
48
豆豆
生活随笔
收集整理的這篇文章主要介紹了
PHP下的浮点运算不准的解决办法
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
首先看一段代碼:
首先看一段代碼:<?php $a = 0.1; $b = 0.7; var_dump(($a + $b) == 0.8);打印出來(lái)的值居然為 boolean falsePHP手冊(cè)摘錄如下:
Warning?
浮點(diǎn)數(shù)精度
顯然簡(jiǎn)單的十進(jìn)制分?jǐn)?shù)如同 0.1 或 0.7 不能在不丟失一點(diǎn)點(diǎn)精度的情況下轉(zhuǎn)換為內(nèi)部二進(jìn)制的格式。這就會(huì)造成混亂的結(jié)果:例如,floor((0.1+0.7)*10) 通常會(huì)返回 7 而不是預(yù)期中的 8,因?yàn)樵摻Y(jié)果內(nèi)部的表示其實(shí)是類似 7.9999999999...。?
這和一個(gè)事實(shí)有關(guān),那就是不可能精確的用有限位數(shù)表達(dá)某些十進(jìn)制分?jǐn)?shù)。例如,十進(jìn)制的 1/3 變成了 0.3333333. . .。
?
解決辦法也不難,php提供了兩個(gè)函數(shù)bcadd()和bcsub().
<?php $a = 0.1; $b = 0.7; var_dump(bcadd($a,$b,2) == 0.8);//輸出為boolean true?當(dāng)然還有一種辦法,就是將mysql的相應(yīng)字段類型設(shè)置為更加精準(zhǔn)的decimal類型。
轉(zhuǎn)載于:https://www.cnblogs.com/phper12580/p/10551932.html
總結(jié)
以上是生活随笔為你收集整理的PHP下的浮点运算不准的解决办法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: C# .NET Web API 如何自訂
- 下一篇: PHP 项目中单独使用 Laravel