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

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

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

当我在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中获得非常高的精度以及数量太少?

解决方法:

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

使用BigDecimal进行计算:

BigDecimal bigNumber = new BigDecimal(1000).pow(10);
System.out.println(bigNumber);
上一篇:Java – BigInteger奇怪的行为


下一篇:Java Stream数字到数字