BigDecima作用:
1.用于小数的精确运算
2.用来表示很大的小数(这点和BigInteger很像)
BigDecima构造方法及静态方法:
直接输出小数的运算结果可以会导致数据错误,从而输出错误的结果
代码演示:
public class Test11 {
public static void main(String[] args) {
//直接输出小数的运算结果可能会出现错误
System.out.println(0.01 + 0.09);
}
}
运行结果:
使用BigDecima创建对象:
创建对象后存储小数再使用成员方法运算就不容易出现错误了
(成员方法在文章后面我会介绍)
代码演示:
public class Test11 {
public static void main(String[] args) {
//使用BigDecima(String val)创建对象再来运算就不会出错了
BigDecimal bd1 = new BigDecimal("0.01");
BigDecimal bd2 = new BigDecimal("0.09");
//在调用add相加,将结果输出
System.out.println(bd1.add(bd2));
}
}
运行结果:
使用静态方法创建对象:
代码演示:
public class Test12 {
public static void main(String[] args) {
//静态方法创建对象
BigDecimal bd1 = BigDecimal.valueOf(0.01);
BigDecimal bd2 = BigDecimal.valueOf(0.09);
BigDecimal result = bd1.add(bd2);
System.out.println(result);
}
}
运行结果:
注意:
如果要表示的数字不大,没有超过double的取值范围,建议使用静态方法。
如果要表示的数字比较大,超过了double的取值范围,建议使用构造方法
若使用静态方法时,输入的参数为1 ~ 10的整数,因为这十个整数再BigDecima中提前定义好了,所以创建的对象会直接存储已经定义好的那个整数的地址值,并且如果创建多个对象都存储的是1 ~ 10中的同一个整数,那它们存储的地址值是一样的
BigDecima成员方法:
加减乘除:
代码演示:
public class Test13 {
public static void main(String[] args) {
BigDecimal bd1 = BigDecimal.valueOf(8.0);
BigDecimal bd2 = BigDecimal.valueOf(2.0);
//加
BigDecimal bd3 = bd1.add(bd2);
//减
BigDecimal bd4 = bd1.subtract(bd2);
//乘
BigDecimal bd5 = bd1.multiply(bd2);
//除
BigDecimal bd6 = bd1.divide(bd2);
System.out.println("加法结果:" + bd3);
System.out.println("减法结果:" + bd4);
System.out.println("乘法结果:" + bd5);
System.out.println("除法结果:" + bd6);
}
}
运行结果:
除法除不尽情况:
若使用上述除法方法时遇到除不尽的情况,程序就会报错,所以我们可以使用下面这种更安全可靠的除法方法。
代码演示
public class Test14 {
public static void main(String[] args) {
BigDecimal bd1 = BigDecimal.valueOf(8.0);
BigDecimal bd2 = BigDecimal.valueOf(3.0);
BigDecimal bd3 = bd1.divide(bd2, 2, RoundingMode.HALF_UP);
System.out.println(bd3);
}
}
如上述代码所示,括号中又加入了两个参数,第二个参数“2”,表示结果保留两位小数,数字是几就保留几位。第三个参数RoundingMode.HALF_UP表示四舍五入,它还有其他许多格式,我放一张图片来展示: