玖叶教程网

前端编程开发入门

BigDecimal精度丢失问题(big decimal 精度)

使用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);

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言