System.out.println(0.04 + 0.01);
System.out.println(1.0 - 0.32);
System.out.println(4.115 * 105);
System.out.println(150.3 / 100);
结果:
0.060000000000000005
0.6799999999999999
432.07500000000005
1.5030000000000001
从以上代码可以当浮点型变量在进行运算的时候会丢失精度,而当对精度有太大要求的时候就要用到BigDecimal。
BigDecimal位于java.math包下
BigDecimal一共有4个构造方法
BigDecimal(int) 创建一个具有参数所指定整数值的对象。
BigDecimal(double) 创建一个具有参数所指定双精度值的对象。
BigDecimal(long) 创建一个具有参数所指定长整数值的对象。
BigDecimal(String) 创建一个具有参数所指定以字符串表示的数值的对象。
BigDecimal 的运算方式 不支持 + - * / 这类的运算 它有自己的运算方法
BigDecimal add(BigDecimal augend) 加法运算
BigDecimal subtract(BigDecimal subtrahend) 减法运算
BigDecimal multiply(BigDecimal multiplicand) 乘法运算
BigDecimal divide(BigDecimal divisor) 除法运算
除法升级:
BigDecimal divide(BigDecimal bd ,int scal, RoundingMode mode)
参数scal:指定精确到小数点后几位
参数mode:
指定小数部分得取舍模式,通常采用四舍五入得模式
取值为BigDecimal.ROUND_UP