关于有小数位数的加减乘除 BigDecimal加减乘除

    在Java中关于有小数的加减乘除都是经常遇到的,现在主要说明关于运算后的精度问题,如果你对精度要求不高,查出来的数据本身就只能作为参考,那么自己使用什么类型  Double BigDecimal 等都没有多大的区别。但是如果对于精确到要求比较高的地方那么必须使用 BigDecimal,只有他才能保证你的精度。

    现在来介绍如何使用 BigDecimal ,

// 首先是如何来 创建一个  BigDecimal,有以下方法来创建 ,但是这2个创建的结果是不一样的。
		BigDecimal sum1=new BigDecimal("0.35");
		BigDecimal sum2=new BigDecimal(0.35);
		System.out.println(sum1);
		System.out.println(sum2);
		/*  结果分别为:
		  0.35
		  0.34999999999999997779553950749686919152736663818359375
		   只要有创建带小数的  都要使用  BigDecimal(String val) 这个构造方法,使用其他的会使其精度出现偏差
		  我个人习惯都是 使用  String
		*/
		// 再来看  Double
		Double d1 =new Double("0.35");
		Double d2 =new Double(0.35);
		System.out.println(d1);
		System.out.println(d2);
		// 结果 无差异  都是  1.016
		
		// 对于运算符 
		Double d =new Double("11540");
		System.out.println(d*d1);
		// 结果为: 4038.9999999999995
		
		BigDecimal sum=new BigDecimal("11540");
		System.out.println(sum.multiply(sum1));
		// 结果为 :4039.00
		
		// 在运算时 Double 在某些时候会导致精度不准确(并不是每次都不准确),
		// 所以你不清楚 在什么时候不准确,所以 对精度要求高的计算 都要使用  BigDecimal
		// 下面说下 BigDecimal 的一些常用的方法
		System.out.println("=====================");
		// 加法   11540    0.35
		BigDecimal multiply = sum.add(sum1);
		System.out.println(multiply);
		// 减法 
		BigDecimal subtract = sum.subtract(sum1);
		System.out.println(subtract);
		// 乘法 
		BigDecimal multiply2 = sum.multiply(sum1);
		System.out.println(multiply2);
		
		// 现在重点介绍一下 除法 为什么呢,因为你在使用的时候 可能出现 除不尽 的数
		// 这样的话就会直接  抛出异常   ArithmeticException
		
		//BigDecimal divide = sum.divide(sum1);
		//System.out.println(divide); 这样直接就会报错,只能 其他方法
		
		
		BigDecimal divide = sum.divide(sum1,4,BigDecimal.ROUND_HALF_UP);
		System.out.println(divide);
		
		// 32971.4285714286
		/*  首先来解释下  这些参数 
		 * 第一个就不用说了;第二个是你要  保留几位小数; 
		 * 第三个就比较多了: 主要意思就是 关于这个 主要的 保留几位数的方式
		 *  主要说明常用的
        BigDecimal.ROUND_DOWN    去一法。 直接删除后面的位数。正数负数都一样
        BigDecimal.ROUND_UP      进一法。 不管正负数,只要后面舍去的位数大于0,数字末尾加1
        BigDecimal.ROUND_HALF_UP 四舍五入 不管正负数,后面的数字一律四舍五入
        BigDecimal.ROUND_HALF_DOWN 可以说和ROUND_HALF_UP 有相似的地方,但是后面舍得数字的下一位必须大于 5 才进一。ROUND_HALF_UP 等于 5也会进一

		
		 * 
		 * 其他的就不说,不清楚的可以看源码,记住几个经常使用的就行
		 * 
		 */ 

最后加加上 大小比较的方法,compareTo  -1 小于,0 等于,1 大于

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值