float 转int导致的误差太大,出现下面的问题。

浮点数的精度

浮点数的精度有限。尽管取决于系统,PHP 通常使用 IEEE 754 双精度格式,则由于取整而导致的最大相对误差为 1.11e-16。非基本数学运算可能会给出更大误差,并且要考虑到进行复合运算时的误差传递。
此外,以十进制能够精确表示的有理数如 0.1 或 0.7,无论有多少尾数都不能被内部所使用的二进制精确表示,因此不能在不丢失一点点精度的情况下转换为二进制的格式。这就会造成混乱的结果:例如,floor((0.1+0.7)*10) 通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是类似 7.9999999999999991118…。
所以永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。如果确实需要更高的精度,应该使用任意精度数学函数或者 gmp 函数。

来源: http://www.zjian.me/web/php/php%e4%b8%adfloat%e7%b1%bb%e5%9e%8b%e4%b8%8eint%e8%bd%ac%e6%8d%a2%e7%9a%84%e9%97%ae%e9%a2%98/
GMP函数
http://php.net/manual/en/book.gmp.php
php 处理高精度计算函数 金额计算
shopnc中 微信支付传值的处理方式
$param['orderFee'] = ncPriceYuan2fen($order_pay_info['api_pay_amount']);
ncPriceCalculate 采用三个参数的方式,直接传入+-符号来执行不同的方法,和策略模式有一点点像,个人认为比起定义多个方法去处理要好很多,
在多次计算的时候也可以很清晰的通过符号看逻辑
  1. /**
  2. * PHP精确计算 主要用于货币的计算用
  3. * @param $n1 第一个数
  4. * @param $symbol 计算符号 + - * / %
  5. * @param $n2 第二个数
  6. * @param string $scale 精度 默认为小数点后两位
  7. * @return string
  8. */
  9. function ncPriceCalculate($n1,$symbol,$n2,$scale = '2'){
  10. $res = "";
  11. switch ($symbol){
  12. case "+"://加法
  13. $res = bcadd($n1,$n2,$scale);break;
  14. case "-"://减法
  15. $res = bcsub($n1,$n2,$scale);break;
  16. case "*"://乘法
  17. $res = bcmul($n1,$n2,$scale);break;
  18. case "/"://除法
  19. $res = bcdiv($n1,$n2,$scale);break;
  20. case "%"://求余、取模
  21. $res = bcmod($n1,$n2,$scale);break;
  22. default:
  23. $res = "";break;
  24. }
  25. return $res;
  26. }
  27. /**
  28. * 价格由元转分
  29. * @param $price 金额
  30. * @return int
  31. */
  32. function ncPriceYuan2fen($price){
  33. $price = (int) ncPriceCalculate(100,"*", ncPriceFormat($price));
  34. return $price;
  35. }
  36. /**
  37. * 价格格式化
  38. *
  39. * @param int $price
  40. * @return string $price_format
  41. */
  42. function ncPriceFormat($price) {
  43. $price_format = number_format($price,2,'.','');
  44. return $price_format;
  45. }
总结:对于浮点型的计算,很多人都会采用将金额*100后计算 最后四舍五入为整型,这种方式看起来也是不会有错的,在简单的计算过程中基本出错概率忽略不计,
但是浮点型的计算误差会随着计算量的增大而增大,所以在金额的计算中,还是采用bc类方法计算为好。

null

转载于:https://www.cnblogs.com/wolfgang-/p/6635404.html

php 浮点型float 强转int php金额计算 php元转分相关推荐

  1. float强转int

    本文只讨论float转int的原理,如有不当之处,欢迎留言指出.交流学习. 推荐阅读关于float转int的函数实现(非结构体实现版) 类型强转丢失精度的根源 目录 一.思路 1.1 十进制 1.2 ...

  2. php 浮点型相加后小数点,PHP浮点型(float)转换为整形(int)/round()保留小数点后几位...

    [No00006C]文件名复制,归档小助手[自己写的小工具,希望能帮助大家] 特别补充一句:软件可以一次性复制多个文件的文件名. Windows 中的复制文件名实在是有些不方便 ,需要点右键 &quo ...

  3. C语言实现float类型到int类型的转化(位运算基础知识)

    /* 在很多系统程序中常要求在位(bit)一级进行运算或处理.C语言提供了位运算的功能, 这使得C语言也能像汇编语言一样用来编写系统程序.           ******************** ...

  4. c++:实型(浮点型float,double),sizeof统计float和double的占用内存空间,科学记数法表示小数:e

    c++:实型(浮点型float,double),sizeof统计float和double的占用内存空间,科学记数法表示小数:e 2022找工作是学历.能力和运气的超强结合体,遇到寒冬,大厂不招人,此时 ...

  5. python数据类型【浮点型(float)】

    python数据类型[浮点型(float)] 浮点型,一般在开发中用于表示小数 v1=1.34 浮点数其他知识点: 在浮点型转换为整型时,会将小数部分去掉 v1=3.14 int(v1) 3 保存小数 ...

  6. R语言dataframe数据列格式转换(从整型integer转化为浮点型float)

    R语言dataframe数据列格式转换(从整型integer转化为浮点型float) 目录 R语言dataframe数据列格式转换(从整型integer转化为浮点型float)

  7. 函 float *search(float(*pointer)[4],int n)

    书本277页返回指针值的函数,调用函数输出一个学生的全部科目的成绩. 返回指针值函数的妙用 #include <stdio.h>int main() {float score[][4]={ ...

  8. Java黑皮书课后题第4章:*4.26(金融应用:货币单位)重写程序清单2-10,解决将float型值转换为int型值时可能会造成精度损失的问题。读取的输入值是一个字符串,比如“11.56“

    *4.26(金融应用:货币单位)重写程序清单2-10,解决将float型值转换为int型值时可能会造成精度损失的问题.读取的输入值是一个字符串,比如"11.56" 题目 题目概述 ...

  9. java判断float相等_在java中判断两个浮点型(float)数据是否相等的案例

    示例代码: public static void main(String[] args) { float a = 10.222222225f; float b = 10.222222229f; Sys ...

最新文章

  1. 32岁程序员,补偿N+2:“谢谢裁我,让我翻倍!” 网友:榜样!
  2. html语言字体是否依赖客户端,【前端面试】HTML5+CSS3初级面试1
  3. Aspose.Words提示The document appears to be corrupted and cannot be loaded.
  4. MyBatis Plus Generator——基于Velocity的Controller参考模板(集成MyBatis Plus、Swagger2、自封装Response、分页)
  5. 调用支付jsapl缺少参数:totalfee openid无法取得_微信支付的架构到底有多牛?
  6. 重新学习Spring2——IOC和AOP原理彻底搞懂
  7. 小红书点赞收藏有什么用_橱柜门用什么材料好?老师傅开口说话了!听进去算你的,收藏备用...
  8. 66.为什么有时候在ISE软件中,顶层文件不能置顶?
  9. Python编辑和保存Word(docx)
  10. C++二进制文件读写,以及数据的拼合与还原
  11. 仿支付宝输入密码效果
  12. UVA-11584:Partitioning by Palindromes(基础DP)
  13. c语言求最小公倍数_最小公倍数
  14. 请简述独占设备的分配过程。
  15. Maya---操作工具
  16. 怎样在线将图片制作成圆角图样式
  17. 如何写 Cover Letter 论文投稿
  18. 计算机代码英语,计算机专业英语 (四)(示例代码)
  19. 绕线机算法模型(Simulink仿真验证+PLC代码实现)
  20. vaex库使用方法python_Python秒开100G数据是怎么办到的?

热门文章

  1. HDU 1317 XYZZY(floyd+bellman_ford判环)
  2. 使用while循环输入 1 2 3 4 5 6 8 9 10
  3. 华为OJ平台——放苹果(典型整数划分问题)
  4. [Objective-c 基础 - 2.1] 封装
  5. 【转】shell学习笔记(一)——学习目的性、特殊字符、运算符等
  6. python os.walk
  7. lenovo 一键恢复6.0 NOVO下密码遗忘的解决方案
  8. pass information between XXX.Aspx and XXX.Aspx.cs
  9. 三个值得期待的JavaScript新功能!
  10. 诺基亚将携手Nedaa在迪拜设立IoT实验室