前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >php强制转换浮点型到整型出现结果不符合预期

php强制转换浮点型到整型出现结果不符合预期

原创
作者头像
槽痞
修改2020-04-07 11:46:08
1.6K0
修改2020-04-07 11:46:08
举报
文章被收录于专栏:PHP开发者那些事

使用php的浮点数转int型时,出现转换结果不符合预期,直接转换出现问题在其他强类型语言中可能会有意识的去规避,而php能从心所欲,反倒会出现这种细节问题。

代码语言:txt
复制
$a = 0.58;



$b = $a \* 100;



$c = intval($b);



var\_dump($b);// double(58)



var\_dump($c); //int(57)

翻到php的官方文档,对于这个不符合预期的解释:

浮点数的精度

浮点数的精度有限。尽管取决于系统,PHP 通常使用 IEEE 754 双精度格式,则由于取整而导致的最大相对误差为 1.11e-16。非基本数学运算可能会给出更大误差,并且要考虑到进行复合运算时的误差传递。

此外,以十进制能够精确表示的有理数如 0.1 或 0.7,无论有多少尾数都不能被内部所使用的二进制精确表示,因此不能在不丢失一点点精度的情况下转换为二进制的格式。这就会造成混乱的结果:例如,floor((0.1+0.7)*10) 通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是类似 7.9999999999999991118...。

所以永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。如果确实需要更高的精度,应该使用任意精度数学函数或者 gmp 函数。

对于这个问题具体的解决方法:

  • 首推bcmath的相关方法进行转换、比较,具体可自行搜索。
  • 其次可以选将浮点数转字符串,再将字符串转成int类型。
代码语言:txt
复制
$a = 0.58;
$b = $a * 100;
$c = intval((string)$b);
var_dump($b);// double(58)
var_dump($c); //int(57)

引用:

Float 浮点型

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档