龙空技术网

BigDecimal精度丢失问题

Java小行家 944

前言:

目前看官们对“double两位小数”大体比较讲究,咱们都想要分析一些“double两位小数”的相关内容。那么小编同时在网络上汇集了一些关于“double两位小数””的相关文章,希望各位老铁们能喜欢,你们一起来了解一下吧!

使用BigDecimal的构造函数进行封装Double、Float型数值的时候,实际创建的值与我们期望的值会出现误差,因此在进行运算时会出现精度的丢失。如何避免:使用new BigDecimal(String);

public BigDecimal(double val)

1.此构造方法的结果有一定的不可预知性。有人可能认为在 Java 中写入 new BigDecimal(0.1) 所创建的 BigDecimal 正好等于 0.1,但是它实际上等于 0.10000000000000000555111512312578270211815。这是因为 0.1 无法准确地表示 double。这样,传入到构造方法的值不会正好等于 0.1(虽然表面上等于该值)。

2.另一方面,String 构造方法是完全可预知的:写入 new BigDecimal("0.1") 将创建一个 BigDecimal,它正好 等于预期的 0.1。因此,相比较而言,通常建议优先使用 String 构造方法。

3.当 double 必须用作 BigDecimal 的源时,先使用 Double.toString(double) 方法,然后使用 BigDecimal(String) 构造方法,将 double 转换为 String。

double保留两位小数:

double d = 2.125123123123;BigDecimal bigDecimal1 = new BigDecimal(d).setScale(2, RoundingMode.HALF_UP);BigDecimal bigDecimal2 = new BigDecimal(d).setScale(2, BigDecimal.ROUND_HALF_UP);

标签: #double两位小数