我将进行包含大数或小数的计算,并产生非常大或非常小的数字.
我现在关心的是如何让事情尽可能精确.
当我在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);