1、概述
Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。在实际应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,在商业计算中要用java.math.BigDecimal。BigDecimal所创建的是对象,我们不能使用传统的+、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象。
2、构造方法
构造方法用于创建对象
常用的BigDecimal一共由4个构造方法
- BigDecimal BigDecimal(int) 创建一个具有参数所指定整数值的对象。
- BigDecimal BigDecimal(double) 创建一个具有参数所指定双精度值的对象。(不建议采用)
- BigDecimal BigDecimal(long) 创建一个具有参数所指定长整数值的对象。
- BigDecimal BigDecimal(String) 创建一个具有参数所指定以字符串表示的数值的对象.与第二个构造方法结合,先将double数据类型封装为包装类,再转换为String,这样初始生成的对象此不会出现问题
3、对象建立
public class test1112 {
public static void main(String[] args) throws ParseException {
BigDecimal a = new BigDecimal(9);
BigDecimal b = BigDecimal.valueOf(99);//底层代码会建立一个对象
System.out.println(a);
System.out.println(b);
}
}
//输出结果
9
99
4、常用方法
BigDecimal并不能单纯的用运算符"+、-、*、/"做运算需要用对应的方法
- BigDecimal add(BigDecimal);做加法运算
- BigDecimal substract(BigDecimal);做减法运算
- BigDecimal multiply(BigDecimal);做乘法运算
- BigDecimal divide(BigDecimal);做除法运算
- BigDecimal divide (BigDecimal,保留位数,舍入方式);除不尽的时候使用
BigDecimal setScale(保留位数,舍入方式)
BigDecimal(this的n次方) pow(n);求数据的n次幂
5、示例代码
public class test1112 {
public static void main(String[] args) throws ParseException {
String a="10.0";
String b="3.3";
BigDecimal c = new BigDecimal(a);
BigDecimal d = new BigDecimal(b);
System.out.println(c.add(d));
System.out.println(c.subtract(d));
System.out.println(c.multiply(d));
System.out.println(c.divide(d,6,BigDecimal.ROUND_HALF_DOWN));
}
}
//执行结果
13.3
6.7
33.00
3.030303