如何在Java中使用过多的数字和过少的数字来获得非常高的精度?

时间:2014-05-09 08:23:52

标签: java precision biginteger bigdecimal largenumber

我将进行包含大数或小数的计算,并产生非常大或非常小的数字。

我现在关心的是如何让事情尽可能精确

当我在Google计算器上尝试此计算时 1000 ^ 10 = 1e + 30 其中可以读作1000,000,000,000,000,000,000,000,000,000,000

当我使用BigDecimal尝试相同的计算时,我得到了不同的结果!

  BigDecimal bigNumber = new BigDecimal(Math.pow(1000, 10));
  System.out.println(bigNumber);

1000,000,000,000,000,019,884,624,838,656

我很高兴它在没有使用科学记数法的情况下为我提供了全部数字,但它最后给出了一些额外的垃圾数字。

请注意,我并不局限于BigDecimal。无论如何我都很关心精确度。

那么,如何在数量过大的情况下获得非常高的精度以及在Java中使用太少的数字?

1 个答案:

答案 0 :(得分:9)

使用BigDecimal并在double中进行计算与完全不使用BigDecimal相同。

使用BigDecimal进行计算:

BigDecimal bigNumber = new BigDecimal(1000).pow(10);
System.out.println(bigNumber);