当小伙伴们刚接触到计算的时候,特别是精度高的,例如带有小数点的加减乘除,就很可能会遇到精度计算和显示错误的问题。
1.做浮点型加减乘除计算的时候应该会遇到计算结果不准确,或者计算结果为 -1.3322676295502E-15 这样的值。
2.浮点型的数字通过json_encode、serialize函数处理后,数值会莫名奇妙的变了,比如0.20 变为 0.1999999999...
第一种问题的解决办法:用BC高精度数学函数!用BC高精度数学函数!用BC高精度数学函数!
对于任意精度的数学,PHP提供了支持用字符串表示的任意大小和精度的数字的二进制计算。
自 PHP 4.0.4,libbcmath 随同 PHP 一起发布。该扩展不需要任何外部的库。
列出基本的bc函数,如下(详细使用方法请自行百度)
- bcadd — 2个任意精度数字的加法计算
- bccomp — 比较两个任意精度的数字
- bcdiv — 2个任意精度的数字除法计算
- bcmod — 对一个任意精度数字取模
- bcmul — 2个任意精度数字乘法计算
- bcpow — 任意精度数字的成方
- bcpowmod — Raise an arbitrary precision number to another, reduced by a specified modulus
- bcscale — 设置所有bc数学函数的默认小数点保留位数
- bcsqrt — 任意精度数字的二次方根
- bcsub — 2个任意精度数字的减法
第二种问题的解决办法:
1.可以通过调整 php.ini
中 serialize_precision (序列化精度)
的大小来解决这个问题。据查:此问题只出现在PHP 7.1+版本上,将 serialize_precision = -1 。
2.将高精度数值转换为字符串类型。