浮点型 转化 成 整形 那点事



我们都知道  浮点型 不是很精确的,所以在进行类型转化的时候就会出现很多意向不到的问题

我使用php给大家用代码说说这事

$a = 2.01;
var_dump(sprintf('%.20F', $a * 100));//string(24) "200.99999999999997157829"
var_dump( intval( $a * 100) );//int(200)

上面的结果很出人意料吧,2.01 * 100 应该是201吧,居然是200.99999999....  这样就可以解释 为什么 后面的转化成整形变成200了

如何解决这种问题了?   float => int  之前先使用round

$a = 2.01;
var_dump(sprintf('%.20F', $a * 100));//string(24) "200.99999999999997157829"
var_dump( intval( round($a * 100) ) );//int(201)

其实大部分情况都不用太考虑这种问题,但是在支付系统中就要考虑这个问题,因为商品的价格一般需要支付到分,上面的2.01 就是到分。这个时候如果订单数据表中存放的价格单位是分就有问题了,  根据上面的事例很有可能存的就是200,210的商品,最后已200结算了。



终极解决方案 对于精度有要求的使用mysql 的 decimal类型


float int
编程浪子走四方:CodeRonin