如果用php的+-*/计算浮点数的时候,可能会遇到一些计算结果错误的问题,比如echo intval( 0.58*100 );会打印57,而不是58
这个其实是计算机底层二进制无法精确表示浮点数的一个bug,是跨语言的
可以用精度函数库解决问题
bcadd — 将两个高精度数字相加
bccomp — 比较两个高精度数字,返回-1, 0, 1
bcdiv — 将两个高精度数字相除
bcmod — 求高精度数字余数
bcmul — 将两个高精度数字相乘
bcpow — 求高精度数字乘方
bcpowmod — 求高精度数字乘方求模,数论里非常常用
bcscale — 配置默认小数点位数,相当于就是Linux bc中的”scale=”
bcsqrt — 求高精度数字平方根
bcsub — 将两个高精度数字相减
1 /** 2 * 两个高精度数比较 3 * 4 * @access global 5 * @param float $left 6 * @param float $right 7 * @param int $scale 精确到的小数点位数 8 * 9 * @return int $left==$right 返回 0 | $left<$right 返回 -1 | $left>$right 返回 110 */11 var_dump(bccomp($left=4.45, $right=5.54, 2));12 // -113 14 /**15 * 两个高精度数相加16 * 17 * @access global18 * @param float $left19 * @param float $right20 * @param int $scale 精确到的小数点位数21 * 22 * @return string 23 */24 var_dump(bcadd($left=1.0321456, $right=0.0243456, 2));25 //1.0426 27 /**28 * 两个高精度数相减29 * 30 * @access global31 * @param float $left32 * @param float $right33 * @param int $scale 精确到的小数点位数34 * 35 * @return string 36 */37 var_dump(bcsub($left=1.0321456, $right=3.0123456, 2));38 //-1.9839 40 /**41 * 两个高精度数相除42 * 43 * @access global44 * @param float $left45 * @param float $right46 * @param int $scale 精确到的小数点位数47 * 48 * @return string 49 */50 var_dump(bcdiv($left=6, $right=5, 2));51 //1.2052 53 /**54 * 两个高精度数相乘55 * 56 * @access global57 * @param float $left58 * @param float $right59 * @param int $scale 精确到的小数点位数60 * 61 * @return string 62 */63 var_dump(bcmul($left=3.1415926, $right=2.4569874566, 2));64 //7.7165 66 /**67 * 设置bc函数的小数点位数68 * 69 * @access global70 * @param int $scale 精确到的小数点位数71 * 72 * @return void 73 */ 74 bcscale(3);75 var_dump(bcdiv('105', '6.55957')); 76 // 16.007