由于原生的(primitive)数据类型, 在表示数据的范围上是有限的,所以Java提供了BigInteger这样的大整数类型。
那么基于JVM的Scala提供的大整数是和Java的BigInteger之间有什么区别呢?
首先,来看一下BigInteger和Scala的BigInt之间在求阶乘中使用的区别。
// Java's BigInteger version
import java.math.BigInteger
def factorial(x: BigInteger): BigInteger =
if (x == BigInteger.ZERO)
BigInteger.ONE
else
x.multiply(factorial(x.subtract(BigInteger.ONE)))
// Scala's BigInt version
def factorial(x: BigInt): BigInt =
if (x == 0) 1 else x * factorial(x - 1)
可以看到,Java的大整数需要使用multiply()和subtract(), BigInteger.ZERO这样的专用方法和字段,而使用Scala的BigInt这像是使用原生类型一样方便。造成这样的区别的原因,应该是Java不支持加减号等运算符的重载造成的。而在Scala中,运算符实质上是对象的一个方法而已,代码写起来也很直观。
然后,BigInt是通过包装(wrap) BigInteger实现的,这就是它们之间的联系。