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.1000000000000000055511151231257827021181583404541015625, 28 正確使用BigDecimal,程序就能夠打印出咱們所期 29 30 望的結果0.9: 31 32 System.out.println(new BigDecimal("2.0").subtract(new BigDecimal("1.10")));// 0.9 33 34 35 36 另外,若是要比較兩個浮點數的大小,要使用BigDecimal的compareTo方法。