BigInteger和BidDecimal可以处理包含任意长度数字序列的数值。BigInteger类实现了任意精度的整数运算,BigDecimal实现了任意精度浮点数运算。
1.
BigInteger a=new BigInteger("12");//a=12
BigInteger b=BigInteger.valueOf(12);//b=12
2.BigDeciaml由任意精度的整数非标度值和32位整数的标度值(scale)组成,
如果为0或正数,则标度是小数点后的位数,如果为负数,则将该数的非标度值乘以10的负scale次幂
BigDecimal c=new Bigdecimal(1.22);
System.out.println(c);//可能为1.2199999999999999,参数为double的构造方法的结果具有一定的不可预知性,1.22无法准确的表示为double
BigDecimal d=new BigDecimal("1.22");
System.out.println(d);//d=1.22
BigDecimal e=BigDouble.valueOf(1.22);//e=1.22
3.对于此类大数值,不能使用传统的运算符“+-*/%”,而需要使用大数值类的add,subtract,multiply,divide,mod等方法
4.int compareTo(BigInteger other)//如果这个大整数和另一个大整数相等,返回0,如果这个大整数小于另一个大整数other,返回负数,否则返回,正数
5. static BigDecimal valueOf(long x,int scale)//返回值为x/(10的scale次方)的一个大实数
BigDecimal a=BigDecimal.valueOf(1234,3)//a=1.234
6.舍入方式
double a=2,b=2.1,c=2.5,d=2.9;
System.out.println(Math.floor(d));//正数则截断2.0
System.out.println(Math.floor(-2.9));//负数则取负无穷大-3.0
System.out.println(Math.ceil(d));//正数向正无穷3.0
System.out.println(Math.ceil(2.1));//正数向正无穷3.0
System.out.println(Math.ceil(-2.9));//负数则截断
//返回最接近参数的整数值
System.out.println(Math.rint(d));
System.out.println(Math.rint(c));//2.5---->2.0
System.out.println(BigDecimal.valueOf(d).setScale(0, BigDecimal.ROUND_UP));
//只要在要求的精度后面有非零值,则进位加一
System.out.println(BigDecimal.valueOf(d).setScale(0, BigDecimal.ROUND_DOWN));
//直接截断
System.out.println(BigDecimal.valueOf(d).setScale(0, BigDecimal.ROUND_FLOOR));
//同Math里的floor方法
System.out.println(BigDecimal.valueOf(c).setScale(0, BigDecimal.ROUND_HALF_DOWN));
//四舍五入,但2.5---->2
System.out.println(BigDecimal.valueOf(c).setScale(0, BigDecimal.ROUND_HALF_UP));
//四舍五入,但2.5---->3
System.out.println(BigDecimal.valueOf(c).setScale(0, BigDecimal.ROUND_HALF_EVEN));
System.out.println(BigDecimal.valueOf(1.5).setScale(0, BigDecimal.ROUND_HALF_EVEN));
/*向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
* 如果舍弃部分左边的数字为奇数,则舍入行为与 ROUND_HALF_UP 相同;
如果为偶数,则舍入行为与 ROUND_HALF_DOWN 相同。
注意,在重复进行一系列计算时,此舍入模式可以将累加错误减到最小。*/