-
為什么不使用float / double?
使用java時會遇到money類型的選擇問題,首先想到的是float / double。如果只是簡單的貨幣計算,很難發現用float會有問題。出現問題的原因是使用float / double(已經相應的包裝類Float / Double)會出現舍入誤差(rounding errors),不能精確的表示十進制數。例如下面的例子:
1 public class countMoney {
2 public static void main(String[] args) {
3 float m1 = 0.1f;
4 float m2 = 9.0f;
5 System.out.println(mulMoney(m1, m2));
6 }
7
8 private static float mulMoney(float m1, float m2) {
9 return m1 * m2;
10 }
11 }
結果輸出0.90000004,而不是0.9。十進制數0.1用二進制存儲,被表示的值為0.0999999999999999996。所以得到的結果並不是預期的0.9。
-
怎樣表示money?
使用BigDecimal來表示貨幣。現在來重新實現這個例子:
1 public class countMoney {
2 public static void main(String[] args) {
3 BigDecimal m1 = new BigDecimal("0.1");
4 BigDecimal m2 = new BigDecimal("9.0");
5 System.out.println(mulMoney(m1, m2));
6 }
7
8 private static BigDecimal mulMoney(BigDecimal m1, BigDecimal m2) {
9 return m1.multiply(m2);
10 }
11 }
輸出0.90。
BigDecimal可表示任意精度的小數,不管它的范圍有多大。BigDecimal是用array來存儲數字的,每一次輸入表示一個數字。因此,BigDecimal可以表示任意大小的數。
另外,BigDecimal是一個類,不是基本類型,需要調用方法來實現數的運算。它有四中方法:add, subtract, multiply, 和 divide。這里m1和m2相乘采用了multiply。
-
表示money的其他方法?
用currency可表示世界貨幣。
使用int / long表示penny。
-
參考文獻: