如果基本的整数和浮点数精度不够满足需求,那么可以使用java.math包中的两个很有用的类:BigInteger和BigDecimal。这两个类可以处理包含任意长度数字序列的数值。BigInteger类实现了任意精度的整数运算,BigDecimal类实现了任意精度的浮点数运算。
使用静态的valueOf方法可以将普通的数值转换为大数值:
BigInteger a = BigInteger.valueOf(100);
但是,不能使用人们熟悉的算术运算符(如:+和*)处理大数值。而需要使用大数值类中的add和multiply方法。
bigInteger c = a.add(b); //c = a+b;
BigInteger d = c.multiply(b.add(BigInteger.valueOf(2))); //d = c*(b+2)
java.math.BigInteger
- BigInteger add(BigInteger other)--------和
- BigInteger subtract(BigInteger other)---------差
- Biginteger multiply(BigInteger other)----------积
- BigInteger divide(BigInteger other)-----------除
- BigInteger mod(BigInteger other)-----------余
- int compareTo(BigInteger other)
如果这个大整数与另一个大整数other相等,返回0;小于返回负数;大于返回正数。
- static BigInteger valueOf(long x)
返回值等于x的大整数
- BigDecimal add(BigDecimal other)----------和
- BigDecimal substract(BigDecimal other)---------差
- BigDecimal multiply(BigDecimal other)----------积
- BigDecimal divide(BigDecimal other RoundingMode mode)--------商
想要计算商,必须给出舍入方式(round mod)。
- int compareTo(BigDecimal other)
参考整数。
- static BigDecimal valueOf(long x)
- static BigDecimal valueOf(long x, int scale)
返回值为x或x/10scale 的一个大实数。