BigInteger和BigDecimal基本使用

149 阅读2分钟

BigInteger和BigDecimal

 BigInteger  计算较大整数
 BigDecimal  计算较大整数包括小数

基本的类型或(基本类型的包装类型)计算会导致结果精度丢失

如:

 Float f1 = 1.7F;
 Float f2 = 1F;
 System.out.println(f1 - f2);
 // 结果:0.70000005

BigDecimal:

 BigDecimal bi1 = new BigDecimal("1.7");
 BigDecimal bi2 = new BigDecimal("1");
 System.out.println(bi1.subtract(bi2));
 // 结果:0.7

BigInteger不能使用这种会报错、不支持使用小数

基本加减乘除

 System.out.println(bi1.add(bi2));       // 加
 System.out.println(bi1.subtract(bi2));  // 减
 System.out.println(bi1.multiply(bi2));  // 乘
 System.out.println(bi1.divide(bi2));    // 除

注意事项

 // ROUND_DOWN
 BigDecimal bi1 = new BigDecimal("10.225");
 System.out.println(bi1.setScale(2, BigDecimal.ROUND_DOWN)); // 10.22 舍去模式、并保留两位小数
 ​
 ​
 // ROUND_UP
 BigDecimal bi1 = new BigDecimal("2.2211");
 System.out.println(bi1.setScale(2, BigDecimal.ROUND_UP));// 2.23  包留两位小数、最后面小数+1
 ​
 // ROUND_CEILING
 BigDecimal bi1 = new BigDecimal("2.2211");
 System.out.println(bi1.setScale(2, BigDecimal.ROUND_CEILING));// 2.23  包留两位小数、如第三位大于0则第二位就+1   和ROUND_UP一样
 // ROUND_CEILING
 BigDecimal bi1 = new BigDecimal("-2.2211");
 System.out.println(bi1.setScale(2, BigDecimal.ROUND_CEILING));// -2.22  如果是负数 包留两位小数 和ROUND_DOWN一样
 ​
 ​
 // ROUND_FLOOR
 BigDecimal bi1 = new BigDecimal("2.2291");
 System.out.println(bi1.setScale(2, BigDecimal.ROUND_FLOOR)); //  2.22  如果是正数就保留两位 和ROUND_DOWN一样
 BigDecimal bi1 = new BigDecimal("-2.2291");
 System.out.println(bi1.setScale(2, BigDecimal.ROUND_FLOOR));// -2.23  如果是负数就保留两位数、最后面小数+1 和ROUND_UP一样
 ​
 ​
 ​
 //ROUND_HALF_UP
 BigDecimal bi1 = new BigDecimal("2.2251");
 System.out.println(bi1.setScale(2, BigDecimal.ROUND_HALF_UP)); // 2.23  四舍五入(若舍弃部分>=.5,就进位)
 ​
 // ROUND_HALF_DOWN
 BigDecimal bi1 = new BigDecimal("2.2250");
 System.out.println(bi1.setScale(2, BigDecimal.ROUND_HALF_DOWN));//2.22  四舍五入(若舍弃部分>.5,就进位)
 ​
 ​
 ​
 //常用的
 // ROUND_DOWN
 BigDecimal bi1 = new BigDecimal("10.225");
 System.out.println(bi1.setScale(2, BigDecimal.ROUND_DOWN)); // 10.22 舍去模式、并保留两位小数
 ​
 //ROUND_HALF_UP
 BigDecimal bi1 = new BigDecimal("2.2251");
 System.out.println(bi1.setScale(2, BigDecimal.ROUND_HALF_UP)); // 2.23  四舍五入(若舍弃部分>=.5,就进位)

基本方法

 BigInteger abs()  返回大整数的绝对值
 BigInteger add(BigInteger val) 返回两个大整数的和
 BigInteger and(BigInteger val)  返回两个大整数的按位与的结果
 BigInteger andNot(BigInteger val) 返回两个大整数与非的结果
 BigInteger divide(BigInteger val)  返回两个大整数的商
 double doubleValue()   返回大整数的double类型的值
 float floatValue()   返回大整数的float类型的值
 BigInteger gcd(BigInteger val)  返回大整数的最大公约数
 int intValue() 返回大整数的整型值
 long longValue() 返回大整数的long型值
 BigInteger max(BigInteger val) 返回两个大整数的最大者
 BigInteger min(BigInteger val) 返回两个大整数的最小者
 BigInteger mod(BigInteger val) 用当前大整数对val求模
 BigInteger multiply(BigInteger val) 返回两个大整数的积
 BigInteger negate() 返回当前大整数的相反数
 BigInteger not() 返回当前大整数的非
 BigInteger or(BigInteger val) 返回两个大整数的按位或
 BigInteger pow(int exponent) 返回当前大整数的exponent次方
 BigInteger remainder(BigInteger val) 返回当前大整数除以val的余数
 BigInteger leftShift(int n) 将当前大整数左移n位后返回
 BigInteger rightShift(int n) 将当前大整数右移n位后返回
 BigInteger subtract(BigInteger val)返回两个大整数相减的结果
 byte[] toByteArray(BigInteger val)将大整数转换成二进制反码保存在byte数组中
 String toString() 将当前大整数转换成十进制的字符串形式
 BigInteger xor(BigInteger val) 返回两个大整数的异或