专业的JAVA编程教程与资源

网站首页 > java教程 正文

BigDecimal精度丢失问题(bigdecimal精度设置)

temp10 2024-10-07 15:35:24 java教程 10 ℃ 0 评论

使用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(虽然表面上等于该值)。

BigDecimal精度丢失问题(bigdecimal精度设置)

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

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表