Double类型精度缺失-19.9变为19.89

好久没更新了,从年前忙项目上线到过年等一系列事把计划都耽误了,要调整一下了

公司项目在添加商品的时候当商品价格输入为19.9的时候,录入到数据库就变为19.89了
经过debug调试后发现

int a = (int)(19.9 *100);

这段代码出了问题 原来

19.9 作为 Double 类型表示,二进制形式是:
1 00000000110 011111001100110011001100110011001100110011001100110
(注意中间的两个空格,如果你不知道啥意思,就去查查double的内存表示形式吧)
但是19.9 * 100 由于是二进制运算的结果是
1 00000010011 111000101111111111111111111111111111111111111111111
由于后面有n个11111所以我猜测可能发生了溢出被计算机舍去了.
于是这个数字比 1990少那么一点点(可能是 1989.99999999…)
但是你的取整操作却直接截断了后面的数字,于是成了1989

解决办法:
使用BigDecimal做运算

http://baike.baidu.com/link?url=7iTValVRzH5jrQGuAvaqB7TLokMa8QGZTgBxv8FUNRXEmiKunAPr4DGHuhaNtWitfFPWoWKiOIYw296TmGuXUq

BigDecimal bignum1 = new BigDecimal("19.9");  
BigDecimal bignum2 = new BigDecimal("100");
BigDecimal bignum3 = bignum1.multiply(bignum2); //乘法运算 
int result = bignum3 .intValue();

你可能感兴趣的:(Double类型精度缺失-19.9变为19.89)