-
为什么不使用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。
-
参考文献: