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方法。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM