在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 大于