概述
在JAVA中BigInteger和BigDecimal通常在数字过大使用普通包装类型出现溢出或者存在精度丢失时使用。
相同之处在于JAVA中BigInteger和BigDecimal都采用构造方法创建BigInteger和BigDecimal对象,并且传入的值都是字符串。
BigDecimal bd1 = new BigDecimal("2.05");
BigInteger bi2 = new BigInteger("2123132132");
相同之处BigInteger和BigDecimal在进行加减乘除幂运算时都调用 add subtract multiply divide和pow方法
BigInteger num = bi1.add(bi2);
BigInteger num1 =bi1.subtract(bi2);
BigInteger num2 =bi1.multiply(bi2);
BigInteger num3 =bi1.divide(bi2);
BigInteger num5 =bi1.pow(2147483647);
特别的是在BigDecimal调用除法divide方法时可能出现除不尽的情况 需要注意保留的小数,以及小数的形式
BigDecimal result = bd1.divide(bd4,10,RoundingMode.HALF_UP);
在BigInteger和BigDecimal中实现类型的转换通常调用 XXXValue方法 XXX可以为基本数据类型。
BigInteger bi1 = new BigInteger("11111111111111111111111111111111111");
System.out.println("整型"+bi1.intValue());
System.out.println("长整型"+bi1.longValue());
System.out.println("浮点型"+bi1.doubleValue());
若在BigInteger和BigDecimal中实现类型的转换通常调用 XXXValueExact方法 XXX可以为基本数据类型。如果出现溢出现象则会抛出异常
BigInteger bi1 = new BigInteger("11111111111111111111111111111111111");
BigInteger bi2 = new BigInteger("2123132132");
BigInteger num = bi1.add(bi2);
System.out.println(num.intValueExact());
特别的是当float类型的浮点数超出范围(溢出)时结果为Infinity 无穷
BigInteger bi3 = bi1.pow(999);
System.out.println(bi3.floatValue());
在BigInteger中取余的方法为mod
BigInteger bi1 = new BigInteger("11111111111111111111111111111111111");
BigInteger bi2 = new BigInteger("2123132132");
BigInteger num4 =bi1.mod(bi2);
在BigDecimal中存在stripTrailingZeros方法去除末尾的0
若对小数使用stripTrailingZeros方法则输出去除末尾0后的小数值
若对整数使用stripTrailingZeros方法则输出整数的科学计数法
若对小数使用scale方法 则返回小数的位数
若对整数先使用stripTrailingZeros方法后使用scale方法返回负数则 为整数末尾0的个数。
BigDecimal bd3 = new BigDecimal("2.4500");
BigDecimal bd4 = bd3.stripTrailingZeros();
System.out.println(bd3.stripTrailingZeros());
System.out.println(bd4.scale());
BigDecimal bd5 = new BigDecimal("24500");
BigDecimal bd6 = bd5.stripTrailingZeros();
System.out.println(bd6 );
System.out.println(bd6.scale());
在BigDecimal中存在setScale方法用来设置小数的位数。(小数位数 RoundingMode.HALF_UP)代表四舍五入输出。(小数位数 RoundingMode.DOWN)代表直接输出。
BigDecimal bd1 = new BigDecimal("123.123456789");
BigDecimal bd4 = new BigDecimal("1.6789");
BigDecimal bd2 = bd1.setScale(3, RoundingMode.HALF_UP);
BigDecimal bd3 = bd1.setScale(4, RoundingMode.DOWN);
在BigDecimal中存在divideAndRemainder方法用来保存商和余数,返回值是一个BigDecimal类型的数组。
BigDecimal bd1 = new BigDecimal("123.123456789");
BigDecimal[] result1 = bd1.divideAndRemainder(bd4);
System.out.println(result1[0]);
System.out.println(result1[1]);
在在BigDecimal中比较大小采用compareTo方法进行比较大小
BigDecimal bd1 = new BigDecimal("123.123456789");
BigDecimal bd4 = new BigDecimal("1.6789");
System.out.printf("bd1>bd2:%sn",(bd1.compareTo(bd2)>0));
System.out.printf("bd1<bd2:%sn",(bd1.compareTo(bd2)<0));
System.out.printf("bd1==bd2:%s",(bd1.compareTo(bd2)==0));
最后
以上就是激动啤酒为你收集整理的JAVA中BigInteger和BigDecimal的使用的全部内容,希望文章能够帮你解决JAVA中BigInteger和BigDecimal的使用所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复