首頁  >  文章  >  後端開發  >  解析php處理浮點數、精確度運算、數位處理等

解析php處理浮點數、精確度運算、數位處理等

藏色散人
藏色散人轉載
2021-05-14 11:46:475991瀏覽

這篇文章跟大家介紹php處理浮點數、精確度運算、數位處理等。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

前言

1. php浮點類型數字進行運算 稍微不留神就會出現偏差 商業訂單,商務

2. 浮點數的精確度有限。儘管取決於系統,PHP 通常使用 IEEE 754 雙精度格式,則由於取整而導致的最大相對誤差為 1.11e-16。非基本數學運算可能會給出更大誤差,並且要考慮到進行複合運算時的誤差傳遞。永遠不要相信浮點數結果精確到了最後一位,也永遠不要比較兩個浮點數是否相等。如果確實需要更高的精度,應該使用任意精度數學函數 或 gmp 函數。

一.運算

錯誤

 //加
 $a = 0.1; $b = 0.7; $c = intval(($a + $b) * 10); echo $c."0c6dc11e160d3b678d68754cc175188a"; //输出:7
     //减
 $a = 100; $b = 99.98; $c = $a - $b; echo $c."0c6dc11e160d3b678d68754cc175188a"; //输出:0.019999999999996
     //乘
 $a = 0.58; $b = 100; $c = intval($a * $b); echo $c."0c6dc11e160d3b678d68754cc175188a"; //输出:57
     //除
 $a = 0.7; $b = 0.1; $c = intval($a / $b); echo $c."0c6dc11e160d3b678d68754cc175188a"; //输出:6

正確

##1.對於任意精度的數學,PHP 提供了支援用字串表示的任意大小和精度的數字的二進位計算。

2. 官方手冊:php.net/manual/zh/book.bc.php
3. 大家在使用前,請先確認是否已安裝 bcmath。

 //加
 $a = 0.1; $b = 0.7; $c = intval(bcadd($a, $b, 1) * 10); echo $c."0c6dc11e160d3b678d68754cc175188a"; //输出:8
     //减
 $a = 100; $b = 99.98; $c = bcsub($a, $b, 2); echo $c."0c6dc11e160d3b678d68754cc175188a"; //输出:0.02
     //乘
 $a = 0.58; $b = 100; $c = intval(bcmul($a, $b)); echo $c."0c6dc11e160d3b678d68754cc175188a"; //输出:58
     //除
 $a = 0.7; $b = 0.1; $c = intval(bcp($a, $b)); echo $c."0c6dc11e160d3b678d68754cc175188a"; //输出:7

除了加減乘除,bcmath 還提供了以下方法:

1. bccomp 比較兩個任意精確度的數字

2. bcmod 對一個任意精確度數字取模
3. bcpow 任意精確度數字的乘方
4. bcpowmod 高精準度數字乘方求模
5. bcscale 設定所有bc數學函數的預設小數點保留位數
6. bcsqrt任意精度數字的二次方根

二. 常用數值處理方案

捨去法取整(向下取整)
echo floor(5.1);
//输出:5

echo floor(8.8);
//输出:8

進一法取整(向上取整)

echo ceil(5.1);
//输出:6

echo ceil(8.8);
//输出:9

普通四捨五入法

echo round(5.1);
//输出:5

echo round(8.8);
//输出:9

//保留两位小数并且进行四舍五入
echo round(5.123, 2);
//输出:5.12

echo round(8.888, 2);
//输出:8.89

//保留两位小数并且不进行四舍五入
echo substr(round(5.12345, 3), 0, -1);
//输出:5.12

echo substr(round(8.88888, 3), 0, -1);
//输出:8.88

銀行家舍入法

1. 四捨六入五考慮,五後非空就進一,五後為空看奇偶,五前為偶應捨去,五前為奇要進一。

2. 保留兩位小數 例:

 1.2849 = 1.28 -> 四舍
 1.2866 = 1.29 -> 六入
 1.2851 = 1.29 -> 五后非空就进一
 1.2850 = 1.28 -> 五后为空看奇偶,五前为偶应舍去
 1.2750 = 1.28 -> 五后为空看奇偶,五前为奇要进一

數值格式化(千位元分組)

1. 套用於金額的展示,例如我們經常會看的銀行卡餘額。

 echo number_format('10000.98', 2, '.', ','); //输出:10,000.98
     echo number_format('340888999', 2, '.', ',');
 //输出:340,888,999.00

推薦學習:《
PHP影片教學

以上是解析php處理浮點數、精確度運算、數位處理等的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:learnku.com。如有侵權,請聯絡admin@php.cn刪除