在api文档中double类型的构造函数中有如下说明
- public BigDecimal(double val)
- 这个构造函数的结果可能有些不可预测。 可以假设在Java中写入
new BigDecimal(0.1)
创建一个BigDecimal
,它完全等于0.1(非标尺值为1,比例为1),但实际上等于0.1000000000000000055511151231257827021181583404541015625。 这是因为0.1不能像double
(或者作为任何有限长度的二进制分数)精确地表示。 因此,正在被传递给构造的值不是正好等于0.1,虽然表面上。 - 该
String
构造,在另一方面,是完全可以预测的:写new BigDecimal("0.1")
创建BigDecimal
这正好等于0.1,正如人们所期望的那样。 因此, 一般建议使用String constructor优先于此。 - 当
double
必须用作源为BigDecimal
,注意,此构造提供了一个精确的转换; 它不会将double
转换为String
使用Double.toString(double)
方法,然后使用BigDecimal(String)
构造函数相同的结果。 要获得该结果,请使用static
valueOf(double)
方法。 - 将
double
转换为BigDecimal
,这是double
的二进制浮点值的精确十进制表示。 返回的BigDecimal
是(10scale × val)是一个整数的最小值。
- 这个构造函数的结果可能有些不可预测。 可以假设在Java中写入
- 其中
- 可以假设在Java中写入
new BigDecimal(0.1)
创建一个BigDecimal
,它完全等于0.1(非标尺值为1,比例为1),但实际上等于0.1000000000000000055511151231257827021181583404541015625。 - 写
new BigDecimal("0.1")
创建BigDecimal
这正好等于0.1,正如人们所期望的那样。
- 可以假设在Java中写入
- 因此在创建BigDecimal的时候选择string类型的构造函数创建较好