黑马程序员技术交流社区
标题:
为什么浮点数会丢失精度?
[打印本页]
作者:
王新年
时间:
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