A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

© 王新年 中级黑马   /  2013-12-7 15:22  /  1053 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

在下面这段代码中为什么浮点数会丢失精度?
public class Doubles {  
   public static void main(String[] args) {  
      System.out.println(new BigDecimal("2.0").subtract(new BigDecimal("1.1")));  
       System.out.printf("%.1f", 2.0-1.1);//比较 System.out.println(2.0 - 1.1)  =0.8999999999999999   
   }  
}  

1 个回复

倒序浏览
Java 中的 Double,本身就是不精确的。
如果楼主测试以下数字,就会发现
2.4 + 1.2
1 - 0.42
4.015 * 100
123.1 / 100
要想解决这一问题,需要使用java.math.BigDecimal类,里面有一个构造函数,选择BigDecimal("1")String类型的构造器,这样保证精确,不能BigDecimal(1)。然后使用BigDecimal的四个加减乘除方法。进行计算,值得注意的是,在使用除法时(例如 1/3 ),要在使用3个参数的方法,divide(BigDecimal divisor, int scale,  int roundingMode);否则就会出现异常,或数值不准确。

评分

参与人数 1技术分 +1 收起 理由
简★零度 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马