黑马程序员技术交流社区

标题: 为什么浮点数会丢失精度? [打印本页]

作者: 王新年    时间: 2013-12-7 15:22
标题: 为什么浮点数会丢失精度?
在下面这段代码中为什么浮点数会丢失精度?
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   
   }  
}  

作者: 25343215    时间: 2013-12-7 15:55
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);否则就会出现异常,或数值不准确。




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2