我将进行包含大数或小数的计算,并产生非常大或非常小的数字。
我现在关心的是如何让事情尽可能精确。
当我在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中使用太少的数字?
答案 0 :(得分:9)
使用BigDecimal
并在double
中进行计算与完全不使用BigDecimal
相同。
使用BigDecimal
进行计算:
BigDecimal bigNumber = new BigDecimal(1000).pow(10);
System.out.println(bigNumber);