我有一个非常大的数字 ( number1 ) 存储为 aBigInteger
和 a double
(number2)。我计划将number1和number2相乘,并将结果存储为双精度数。
使用该multiply()
方法并没有帮助我实现这一目标。前进的方向是什么?
我有一个非常大的数字 ( number1 ) 存储为 aBigInteger
和 a double
(number2)。我计划将number1和number2相乘,并将结果存储为双精度数。
使用该multiply()
方法并没有帮助我实现这一目标。前进的方向是什么?
为了尽可能长时间地保持任意精度,请在 中进行乘法运算BigDecimal
,然后将结果转换为double
,如下所示:
BigDecimal tmp = new BigDecimal(myBigInteger);
tmp = tmp.multiply(new BigDecimal(myDouble));
double res = tmp.doubleValue();
最简单的解决方案可能是big.doubleValue() * myDouble
.
不幸的是,这不会特别快,因为BigInteger.doubleValue()
实施速度非常慢。(将来可能会更快......也许如果 Oracle 应用我的补丁。)
或者,您可以使用Guavadouble
将 a直接舍入为 a 。BigInteger
DoubleMath.roundToBigInteger(double, RoundingMode)
调用.doubleValue()
BigInteger,并将它们作为双精度数相乘。
为什么BigInteger#multiply()
没有帮助?实际上只有两个合理的答案:
BigInteger a = /* whatever */;
double b = /* whatever */
// either
double result = a.multiply(new BigInteger(b)).doubleValue();
// or
double result = a.doubleValue() * b;