php 高精度函数,php如何处理高精度计算函数

本文介绍了PHP处理高精度计算的两种方法:一是使用BCMath扩展提供的函数,如bcadd、bcscale等进行任意精度数学运算;二是针对浮点数精度问题,通过将计算过程放大避免精度损失,例如将乘法变为乘以1000再除以10的方法。同时,文章提到了PHP浮点数运算的不精确性,并给出了相关链接深入理解该问题。
摘要由CSDN通过智能技术生成

本文主要和大家分享php如何处理高精度计算函数,主要和大家分享图两种方法,希望能帮助到大家。

方法1:

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

bcadd — 加法

bccomp — 比较

bcp — 相除

bcmod — 求余数

bcmul — 乘法

bcpow — 次方

bcpowmod — 先次方然后求余数

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

bcsqrt — 求平方根

bcsub — 减法

方法二:

最近碰见一个奇怪的问题,商城通过微信支付的订单经常少一分钱,经过排查是PHP浮点运算精度问题造成的

由PHP浮点数运算精度造成的,鸟哥的Bolg有详细的说明。http://www.laruence.com/2013/03/26/2884.html,

小数在二进制表示时,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

解决办法:(int)((0.58*1000)/10) = 58

相关推荐:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值