JAVA中BigInteger和BigDecimal的使用

在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:%s\n",(bd1.compareTo(bd2)>0));
		System.out.printf("bd1<bd2:%s\n",(bd1.compareTo(bd2)<0));
		System.out.printf("bd1==bd2:%s",(bd1.compareTo(bd2)==0));

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值