java 小数精确计算

 1 小数精确计算 
 2 
 3 System.out.println(2.00 -1.10);//0.8999999999999999
 4 
 5 
 6 
 7 上面的计算出的结果不是 0.9,而是一连串的小数。问题在于1.1这个数字不能被精确表示为一个double,所以它被表 
 8 
 9 示为最接近它的double值,该程序从2中减去的就是这个值,但这个计算的结果并非最接近0.9的double值。 
10 
11 
12 通常地说,问题在于并非全部的小数均可以用二进制浮点数精确表示。 
13 
14 
15 二进制浮点对于货币计算是很是不适合的,由于它不可能将1.0表示成10的其余任何负次幂。 
16 
17 
18 解决问题的第一种方式是使用货币的最小单位(分)来表示: 
19 
20 System.out.println(200-110);//90
21 
22 
23 
24 第二种方式是使用BigDecimal,但必定要用BigDecimal(String)构造器,而千万不要用 BigDecimal(double)来构造(也不能将float或double型转换成String再来使用BigDecimal(String)来构造,由于在将float或double转换成String时精度已丢失)。 
25 例如new BigDecimal(0.1), 
26 它将返回一个BigDecimal, 
27 也即0.100000000000000005551115123125782702118158340454101562528 正确使用BigDecimal,程序就能够打印出咱们所期 
29 
30 望的结果0.931 
32 System.out.println(new BigDecimal("2.0").subtract(new BigDecimal("1.10")));// 0.9
33 
34 
35 
36 另外,若是要比较两个浮点数的大小,要使用BigDecimal的compareTo方法。
相关文章
相关标签/搜索