Chinaunix首页 | 论坛 | 博客
  • 博客访问: 275410
  • 博文数量: 159
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1619
  • 用 户 组: 普通用户
  • 注册时间: 2016-01-10 19:58
文章分类

全部博文(159)

分类: Web开发

2016-01-13 22:20:20

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

我使用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类型

原文地址:标签:      

智能推荐

阅读(881) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~