不言不语

您现在的位置是: 首页 >  数据库  >  MYSQL

MYSQL

解决PHP高精度计算问题——bc系列函数

2022-05-31MYSQL
最近在整区块链项目,因为项目需求,用户钱包中的比特币,莱特币,以太坊这些数字货币余额需要精确到小数点后八位,所以需要用到php中bc扩展来进行相关运算

最近在整区块链项目,因为项目需求,用户钱包中的比特币,莱特币,以太坊这些数字货币余额需要精确到小数点后八位,所以需要用到php中bc扩展来进行相关运算,毕竟这些数字货币运算频繁,稍不留神,就容易导致运算出问题,用户钱包余额对不上等相关bug


BC高精确度函数库包含了:相加,比较,相除,相减,求余,相乘,n次方,配置默认小数点数目,求平方。这些函数在涉及到有关金钱计算时比较有用,比如电商的价格计算,用户钱包余额计算


bcadd — 将两个高精度数字相加

bccomp — 比较两个高精度数字,返回-1, 0, 1

bcdiv — 将两个高精度数字相除

bcmod — 求高精度数字余数

bcmul — 将两个高精度数字相乘

bcpow — 求高精度数字乘方

bcpowmod — 求高精度数字乘方求模,数论里非常常用

bcscale — 配置默认小数点位数,相当于就是Linux bc中的”scale=”

bcsqrt — 求高精度数字平方根

bcsub — 将两个高精度数字相减


下面列举几个经典示例

<?php


/**
  * 两个高精度数比较
  * @access global
  * @param string $left
  * @param string $right
  * @param int $scale 精确到的小数点位数
  * @return int $left==$right 返回 0 | $left<$right 返回 -1 | $left>$right 返回 1
  */
var_dump(bccomp($left=4.45, $right=5.54, 2));
// -1
  
  
 /**
  * 两个高精度数相加
  * @access global
  * @param string $left
  * @param string $right
  * @param int $scale 精确到的小数点位数
  * @return string 
  */
var_dump(bcadd($left=1.0321456, $right=0.0243456, 2));
//1.05
 
 
  /**
  * 两个高精度数相减
  * @access global
  * @param string $left
  * @param string $right
  * @param int $scale 精确到的小数点位数
  * @return string 
  */
var_dump(bcsub($left=1.0321456, $right=3.0123456, 2));
//-1.98
  
  
 /**
  * 两个高精度数相除
  * @access global
  * @param string $left
  * @param string $right
  * @param int $scale 精确到的小数点位数
  * @return string 
  */
var_dump(bcdiv($left=6, $right=5, 2));
//1.20
 
 
 /**
  * 两个高精度数相乘
  * @access global
  * @param string $left
  * @param string $right
  * @param int $scale 精确到的小数点位数
  * @return string 
  */
var_dump(bcmul($left=3.1415926, $right=2.4569874566, 2));
//7.71
 
 
 /**
  * 设置bc函数的小数点位数
  * @access global
  * @param int $scale 精确到的小数点位数
  * @return void 
  */ 
bcscale(3);
var_dump(bcdiv('105', '6.55957')); 
//php7.1 16


文章评论