zoukankan      html  css  js  c++  java
  • php 数学函数bc的使用(浮点数计算)

    简介:

    对于任意精度的数学,PHP提供了支持用字符串表示的任意大小和精度的数字的二进制计算,最多为2147483647-1(或0x7FFFFFFF-1)。

    • 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、两个高精度浮点数相加(bcadd)

     /**
      * 两个高精度数相加
      * @access global
      * @param float $left
      * @param float $right
      * @param int $scale 精确到的小数点位数
      * @return string 
      */

    var_dump(bcadd($left=1.0321456, $right=0.0243456, 2)); //1.05

    2、两个高精度浮点数相减(bcsub)

      /**
      * 两个高精度数相减
      * @access global
      * @param float $left
      * @param float $right
      * @param int $scale 精确到的小数点位数
      * @return string 
      */

    var_dump(bcsub($left=1.0321456, $right=3.0123456, 2)); //-1.98

    3、两个高精度浮点数相乘(bcmul)

     /**
      * 两个高精度数相乘
      * @access global
      * @param float $left
      * @param float $right
      * @param int $scale 精确到的小数点位数
      * @return string 
      */

    var_dump(bcmul($left=3.1415926, $right=2.4569874566, 2)); //7.71

    4、两个高精度浮点数相除(bcdiv)

     /**
      * 两个高精度数相除
      * @access global
      * @param float $left
      * @param float $right
      * @param int $scale 精确到的小数点位数
      * @return string 
      */
    
    var_dump(bcdiv($left=6, $right=5, 2));
    //1.20
  • 相关阅读:
    ffmpeg filter过滤器 基础实例及全面解析
    gcc的memcpy性能测试
    repo基本操作
    repo或者git diff -uno差异文件全路径备份
    cmake视频教程
    Rust Macro assert!
    Rust迭代器测试
    钟南山每天喝牛奶
    查网页的最后修改时间
    王勃学习车辆超速监测管理系统
  • 原文地址:https://www.cnblogs.com/starfish29/p/11492742.html
Copyright © 2011-2022 走看看