BigDecimal类的加减乘除

来源:互联网 发布:纸鹤网络验证 编辑:程序博客网 时间:2024/05/21 17:01

对于不需要任何准确计算精度的数字可以直接使用float或double,但是如果需要精确计算的结果,则必须使用BigDecimal类,而且使用BigDecimal类也可以进行大数的操作。BigDecimal类的常用方法如表11-15所示。

表11-15 BigDecimal类的常用方法

序号

   

类型

   

1

public BigDecimal(double val)

构造

将double表示形式转换

为BigDecimal

2

public BigDecimal(int val)

构造

将int表示形式转换为

BigDecimal

3

public BigDecimal(String val)

构造

将字符串表示

形式转换为BigDecimal

4

public BigDecimal add(BigDecimalaugend)

普通

加法

5

public BigDecimal subtract(BigDecimal
subtrahend)

普通

减法

6

public BigDecimal multiply(BigDecimal
multiplicand)

普通

乘法

7

public BigDecimal divide(BigDecimal
divisor)

普通

除法

范例:进行四舍五入的四则运算

  1. packageorg.lxh.demo11.numberdemo;
  2. importjava.math.BigDecimal;
  3. class MyMath{
  4.     publicstaticdoubleadd(double d1,double d2)
           //进行加法运算
  5.         BigDecimal b1 = newBigDecimal(d1);
  6.         BigDecimal b2 = newBigDecimal(d2);
  7.         returnb1.add(b2).doubleValue();
  8.     }
  9.     publicstaticdoublesub(double d1,double d2)
           //进行减法运算
  10.         BigDecimal b1 = newBigDecimal(d1);
  11.         BigDecimal b2 = newBigDecimal(d2);
  12.         returnb1.subtract(b2).doubleValue();
  13.     }
  14.     publicstaticdoublemul(double d1,double d2)
           //进行乘法运算
  15.         BigDecimal b1 = newBigDecimal(d1);
  16.         BigDecimal b2 = newBigDecimal(d2);
  17.         returnb1.multiply(b2).doubleValue();
  18.     }
  19.     publicstaticdoublediv(double d1,
    doubled2,int len){// 进行除法运算
  20.         BigDecimal b1 = newBigDecimal(d1);
  21.         BigDecimal b2 = newBigDecimal(d2);
  22.         returnb1.divide(b2,len,BigDecimal.
    ROUND_HALF_UP).doubleValue();
  23.     }
  24.     publicstaticdoubleround(double d,
    int len){     //进行四舍五入
  25. 操作
  26.         BigDecimal b1 = newBigDecimal(d);
  27.         BigDecimal b2 = newBigDecimal(1);
  28.         //任何一个数字除以1都是原数字
  29.         //ROUND_HALF_UP是BigDecimal的一个常量,
    表示进行四舍五入的操作
  30.         returnb1.divide(b2, len,BigDecimal.
    ROUND_HALF_UP).doubleValue();
  31.     }
  32. }
  33. publicclassBigDecimalDemo01 {
  34.     publicstaticvoid main(String[]args) {
  35.         System.out.println("加法运算:" +
    MyMath.round(MyMath.add(10.345,
  36. 3.333), 1));
  37.         System.out.println("乘法运算:" +
    MyMath.round(MyMath.mul(10.345,
  38. 3.333), 3));
  39.         System.out.println("除法运算:" +
    MyMath.div(10.345, 3.333, 3));
  40.         System.out.println("减法运算:" +
    MyMath.round(MyMath.sub(10.345,
  41. 3.333), 3));
  42.     }
  43. }

其实java的float只能用来进行科学计算或工程计算,在大多数的商业计算中,一般采用java.math.BigDecimal类来进行精确计算。
在使用BigDecimal类来进行计算的时候,主要分为以下步骤:
1、用float或者double变量构建BigDecimal对象。
2、通过调用BigDecimal的加,减,乘,除等相应的方法进行算术运算。
3、把BigDecimal对象转换成float,double,int等类型。
一般来说,可以使用BigDecimal的构造方法或者静态方法的valueOf()方法把基本类型的变量构建成BigDecimal对象。


double 和 BigDecimal 之间的转换

      1.  //将BigDecimal转换为  double

       double height = identification.getHeight().doubleValue();
       double bodyWeight = identification.getBodyWeight().doubleValue();

     2.  //计算结果保留两位小数

      double BMI = (Math.round(bodyWeight / (height * height)*100)/100.0);

    3.  //将double转换为BigDecimal  BigDecimal.valueOf(BMI)

      identification.setBmi(BigDecimal.valueOf(BMI));




0 0
原创粉丝点击