php 精度計算問題
php 精確度計算問題
我們來看一個PHP有趣的現象:var_dump( intval(0.58 * 100 ) ); 猜猜這段程式碼會輸出什麼結果呢?
輸出結果是57,而不是58
這是為什麼呢?這都是浮點運算惹的禍。
其實這些結果都並非語言的 bug,但和語言的實現原理有關, js 所有數字統一為 Number, 包括整形實際上全都是雙精度(double)類型。
而PHP會區分 int 還是 float。不管什麼語言,只要牽涉到浮點運算,都是有類似的問題,使用時一定要注意。
浮點數, 以64位的長度(雙精確度)為例, 會採用1位符號位(E), 11指數位(Q), 52位尾數(M)表示(一共64位) .
符號位元:最高位表示資料的正負,0表示正數,1表示負數。
指數位:表示資料以2為底的冪,指數採用偏移碼表示
尾數:表示資料小數點後的有效數字.
這裡的關鍵點就在於, 小數在二進制的表示, 關於小數如何用二進製表示, 大家可以百度一下, 我這裡就不再贅述, 我們關鍵的要了解, 0.58 對於二進製表示來說, 是無限長的值(下面的數字省掉了隱含的1)..
0.58的二進製表示基本上(52位)是: 0010100011110101110000101000111101011100001010001111
0.57的二進製表示基本上(52位)是: 001000111101011100001010001111010111000010100011110
而兩者的二進位, 如果只是透過這52位元計算的話,分別是:
0.58 -> 0.579999999999999960.57 -> 0.56999999999999960.57 -> 0.5699999999999999
10.具體浮點數乘法, 我們不考慮那麼細, 我們就模糊的以心算來看… 0.58 * 100 = 57.999999999
那你intval一下, 自然就是57了….
##可見,這個問題的關鍵點是: “你看似有窮的小數, 在計算機的二進製表示裡卻是無窮的”PHP浮點型在進行-*%/存在不准確的問題我們可以透過以下常用的高精度函數來解決浮點型運算不準確的問題:
bcadd — 將兩個高精度數字相加bccomp — 比較兩個高精度數字,回傳-1, 0, 1 bcdiv — 將兩個高精度數字相除bcmod — 求高精度數字餘數bcmul — 將兩個高精度數字相乘bcpow — 求高精度數字乘方bcpowmod — 求高精度數字乘方求模,數論裡非常常用bcscale — 配置預設小數點位數,相當於就是Linux bc中的”scale=” bcsqrt — 求高精度數字平方根#bcsub — 將兩個高精度數字相減
#
以上是php 精度計算問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

PHP 8的JIT編譯通過將代碼經常彙編為機器代碼,從而增強了性能,從而使應用程序有益於大量計算並減少執行時間。

本文討論了OWASP在PHP和緩解策略中的十大漏洞。關鍵問題包括注射,驗證損壞和XSS,並提供用於監視和保護PHP應用程序的推薦工具。

本文討論了確保PHP文件上傳的確保,以防止諸如代碼注入之類的漏洞。它專注於文件類型驗證,安全存儲和錯誤處理以增強應用程序安全性。

本文討論了PHP中的對稱和不對稱加密,並比較了它們的適用性,性能和安全差異。對稱加密速度更快,適合大量數據,而不對稱的鍵交換則使用。

PHP中準備的陳述通過防止SQL注入並通過編譯和重用來提高查詢性能,從而增強數據庫的安全性和效率。 Character計數:159

本文討論了在PHP中實施API速率限制的策略,包括諸如令牌桶和漏水桶等算法,以及使用Symfony/Rate-limimiter之類的庫。它還涵蓋監視,動態調整速率限制和手
