php的数字精度如何扩展它

时间:2012-05-16 16:18:41

标签: php javascript floating-point precision

在JavaScript中,此数学运算返回:

1913397 / 13.054 =  146575.53240386088 

但是php中的相同操作返回:

1913397 / 13.054 =  146575.53240386

我想这是因为四舍五入。

如何扩展php的精度?

1 个答案:

答案 0 :(得分:2)

来自an article I wrote for Authorize.Net

一加一等于二,对吗?怎么样.2加1.4倍10?那等于16,对吧?如果您正在使用PHP(或大多数其他编程语言)进行数学计算,那就不是了。

echo floor((0.2 + 1.4) * 10); // Should be 16. But it's 15!

这是由于内部如何处理浮点数。它们以固定的小数位数表示,并且可能导致数字不会像您期望的那样相加。在内部我们的.2加上1.4倍10的例子计算到大约15.9999999998左右。使用不必像百分比那样精确的数字时,这种数学运算很好。但是,当处理金钱精确事项时,一分钱或一美元在这里丢失或在那里很快就会增加,没有人喜欢在任何缺钱的短期内。

BC数学解决方案

幸运的是,PHP提供BC Math extension,“对于任意精度数学,PHP提供二进制计算器,它支持任何大小和精度的数字,表示为字符串。”换句话说,您可以使用此扩展名使用货币值进行精确数学运算。 BC Math extension contains function允许您精确执行最常见的操作,包括additionsubtractionmultiplicationdivision

更好的例子

这是与上面相同的例子,但是使用bcadd()函数为我们做数学运算。它需要三个参数。前两个是我们想要添加的值,第三个是我们希望精确到的小数位数。由于我们正在使用资金,因此我们将精确度设置为两位小数。

echo floor(bcadd('0.2', '1.4', 2) * 10); // It's 16 like we would expect it to be.