JAVA BigDecimal运算以及转换

介绍
BigDecimal类处理高精度计算
Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数,但在实际应用中,可能需要对更大或者更小的数进行运算和处理。一般情况下,对于那些不需要准确计算精度的数字,我们可以直接使用Float和Double处理,但是Double.valueOf(String) 和Float.valueOf(String)会丢失精度;float和double只能用来做科学计算或者是工程计算,在商业计算中要用java.math.BigDecimal。BigDecimal所创建的是对象,我们不能使用传统的+、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象;所以开发中,如果我们需要精确计算的结果,则必须使用BigDecimal类来操作啦!

(一)BigDecimal类的常用的几个构造方法
BigDecimal(int):将int表示形式转换为BigDecimal对象
BigDecimal(String) :将字符串表示形式转换为BigDecimal对象
BigDecimal(double):将double表示形式转换为BigDecimal对象

(二)BigDecimal类的常用方法
add(BigDecimal):BigDecimal对象中的值相加,返回BigDecimal对象
subtract(BigDecimal):BigDecimal对象中的值相减,返回BigDecimal对象
multiply(BigDecimal):BigDecimal对象中的值相乘,返回BigDecimal对象
divide(BigDecimal):BigDecimal对象中的值相除,返回BigDecimal对象
toString():将BigDecimal对象中的值转换成字符串
doubleValue():将BigDecimal对象中的值转换成双精度数
floatValue():将BigDecimal对象中的值转换成单精度数
longValue():将BigDecimal对象中的值转换成长整数
intValue():将BigDecimal对象中的值转换成整数

注意:
/*

  • 尽量不能使用BigDecimal bigDecimal = new BigDecimal(double xx),会造成误差,有小数点的值,不论加减乘除,如果不转成字符
  • 串,会发生丢失精度的情况;关于BigDecimal.valueOf(double xx),源码其实也是通过转换为String类型来的。
    */
    // 或者把double类型转换成String类型
    // 如乘法设置精度后再作计算–保留2位小数,四舍五入 :如果不设置精度会导致小数乘小数导致后面有一堆的小数位
    Double d1 = 2.1;
    Double weightDiscountD = 1.1;
    BigDecimal bWeightDiscountD = BigDecimal.valueOf(weightDiscountD).setScale(2,BigDecimal.ROUND_HALF_DOWN);
    // 以免出现0值导致相乘重量为0
    int bValue = bWeightDiscountD.compareTo(BigDecimal.ZERO);
    // 0代表等于,1代表大于,-1代表小于
    if(bValue != 0 && bValue != -1){ // 以防填入负数
    BigDecimal bWeightD = BigDecimal.valueOf(d1).setScale(2,BigDecimal.ROUND_HALF_DOWN);
    BigDecimal multiplyValue = bWeightDiscountD.multiply(bWeightD).setScale(2,BigDecimal.ROUND_HALF_DOWN);
    System.out.println(multiplyValue.doubleValue());
    }
    一:加减乘除
    BigDecimal big1 = new BigDecimal(“6”);
    BigDecimal big2 = new BigDecimal(“3”);
    BigDecimal big3 = null;
    //加法
    big3 = big1.add(big2);
    System.out.println(“和 是:” + big3);
    //减法
    big3 = big1.subtract(big2);
    System.out.println(“差 是:” + big3);
    //乘法
    big3 = big1.multiply(big2);
    System.out.println(“积 是:” + big3);
    //除法
    big3 = big1.divide(big2);
    System.out.println(“商 是:” + big3);
    二:比较大小
    BigDecimal big1 = new BigDecimal (“110”);
    BigDecimal big2 = new BigDecimal (“120”);
    //使用compareTo方法比较
    //注意:big1 、big2 均不能为null,否则会报空指针
    if(big1.compareTo(big2) == 1){
    System.out.println("big1大于big2 ");
    }
    if(big1.compareTo(big2 ) == -1){
    System.out.println("big1小于big2 ");
    }
    if(big1.compareTo(big2) == 0){
    System.out.println("big1等于big2 ");
    }
    if(big1.compareTo(big2) > -1){
    System.out.println("big1大于等于big2 ");
    }
    if(big1.compareTo(big2) < 1){
    System.out.println("big1小于等于big2 ");
    }

你可能感兴趣的:(Java,java)