我们都知道 浮点型 不是很精确的,所以在进行类型转化的时候就会出现很多意向不到的问题
我使用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
智能推荐
- In MySQL, a zero number equals any string
- OAuth的机制原理讲解及开发流程
- 【运维工具】logrotate 日志管理神器
- 【No.4 Ionic】修改 cordova 插件
- 【php】命名空间 和 自动加载的关系
转载于:https://my.oschina.net/54php/blog/600293