网站专题分类,user pro wordpress,建设网站的技术,公司画册为什么不使用float / double#xff1f;使用java时会遇到money类型的选择问题#xff0c;首先想到的是float / double。如果只是简单的货币计算#xff0c;很难发现用float会有问题。出现问题的原因是使用float / double(已经相应的包装类Float / Double)会出现舍入误差(rou…为什么不使用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 }78 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 }78 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。参考文献