坚持
  • 微信

当前位置:首页 > 后端技术 > PHP >

php 处理高精度计算函数

作者:Azhe 时间:2021-04-09 阅读数: 2712人阅读

PHP 为任意精度数学计算提供了二进制计算器(Binary Calculator),它支持任意大小和精度的数字,以字符串形式描述


bcadd — 加法

bccomp — 比较

bcdiv — 相除

bcmod — 求余数

bcmul — 乘法

bcpow — 次方

bcpowmod — 先次方然后求余数

bcscale — 给所有函数设置小数位精度

bcsqrt — 求平方根

bcsub — 减法

备注:

小数在二进制表示时,0.58对于二进制,是无限长的值

0.58的二进制表示基本上(52位)是: 0010100011110101110000101000111101011100001010001111

0.57的二进制表示基本上(52位)是: 0010001111010111000010100011110101110000101000111101

转换成浮点数(64位双精度)


0.58 -> 0.57999999999999996

0.57 -> 0.56999999999999995

0.58*100 = 57.999999999 

(int)(0.58*100) = 57 

解决办法: 

1.(int)((0.58*1000)/10) = 58

2.(float)bcdiv($a, $b, 2); //给定参数值(表示精 确到第几位),推荐使用



上一篇:

下一篇: