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

$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类型。

$a = 0.58;

$b = $a * 100;

$c = intval((string)$b);

var_dump($b);// double(58)

var_dump($c); //int(57)


**引用:**

标签: none

评论已关闭