关于BigDecimal精度部分总结
BigDecimal类概述
Java中提供了大数字(超过16位有效位)的操作类,即java.math.BigInteger类和java.math.BigDecimal类,用高精度计算。其中BigInteger类是针对大整数的处理类,BigDecimal 类则是针对大小数的处理类。
在商业计算中,对数字精度要求较高,必须使用 BigInteger 类和 BigDecimal 类,它支持任何精度的定点数,可以用它来精确计算货币值。
由于在运算的时候,float类型和double很容易丢失精度,所以一般不用来做计算货币。
由于浮点不精确,程序不太可能从 BigDecimal(double)构造函数中获取预期的值。
new BigDecimal(double)这个构造函数的结果可能有点不可预测。有人可能会假设在Java中编写的BigDecimal(0.1)会创建一个BigDecimal,他恰好是等于0.1(未缩放值为1,标度为1),但它实际上等于 0.1000000000000000055511151231257827021181583404541015625 。这是因为0.1不能精确的表示为double(或者,就此而言,作为任何有限长度的二进制分数)。因此,传递给构造函数的值并不完全等于0.1,尽管有外观。
相反。应该使用BigDecimal.valueOf,它使用封面下的字符串来消除浮点的舍入错误,或者使用String参数的构造函数。
double d = 1.1;
BigDecimal bd1 = new BigDecimal(d); //不合规; 见上面的评论
BigDecimal bd2 = new BigDecimal(1.1); //不合规; 同样的结果
double d = 1.1;
BigDecimal bd1 = BigDecimal.valueOf(d);
BigDecimal bd2 = new BigDecimal(“1.1”); //使用String构造函数将产生精确的值