BigDecimal
主要解决浮点类型运算时,出现的结果失真的问题。
public static void main(String[] args) {
System.out.println(0.1 + 0.2); //0.30000000000000004
System.out.println(1.0 - 0.33); //0.6699999999999999
System.out.println(1.005 * 100); //100.49999999999999
System.out.println(1.301 / 100); //0.013009999999999999
}
一、BigDecimal简介?
BigDecimal是在java.math中的,是java本身就封装好的,用来对超过16位有效位的数进行精确的运算。虽然双精度浮点型变量 double 可以处理16位有效数,但在实际应用中可能需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,使用Double.valueOf(String)和Float.valueOf(String) 会丢失精度。如果我们需要精确计算(如:年利率等)的结果,则必须使用BigDecimal 类来操作。
二、常用方法
1.构造器
public BigDecimal(int val); //创建一个具有参数所指定整数值的对象。
public BigDecimal(double val); //创建一个具有参数所指定双精度值的对象;注:不推荐使用,其本质还是用的的double方式运算。
public BigDecimal(long val); //创建一个具有参数所指定长整数值的对象。
public BigDecimal(String val); //创建一个具有参数所指定以字符串表示的数值的对象。
2.方法
public static BigDecimal valueOf(double val); //转换一个double为 BigDecimal
public BigDecimal add(BigDecimal val) //BigDecimal对象中的值相加,返回新的BigDecimal对象。
public subtract(BigDecimal val) //BigDecimal对象中的值相减,返回新的BigDecimal对象。
public multiply(BigDecimal val) //BigDecimal对象中的值相乘,返回新的BigDecimal对象。
public divide(BigDecimal val) //BigDecimal对象中的值相除,返回新的BigDecimal对象。注:若是除不尽时,会抛出异常。
/* val 为除数参数 、val2 为指定保留位数、val3为舍入模式*/
public divide(BigDecimal val, int val2, RoundingMode val3)
public toString() //将BigDecimal对象的数值转换成字符串。
public doubleValue() //将BigDecimal对象中的值以双精度数返回。
public floatValue() //将BigDecimal对象中的值以单精度数返回。
public longValue() //将BigDecimal对象中的值以长整数返回。
public intValue() //将BigDecimal对象中的值以整数返回。
2.RoundingMode 舍入模式(常用)
1. ROUND_UP
直接进位。保留小数位后存在大于0的数将直接进1。
2. ROUND_DOWN
舍弃多余的小数。
3. ROUND_HALF_UP
四舍五入。
5. ROUND_UNNECESSARY
不做舍入。若计算结果不满足保留小数结果将会抛出异常(如:保留一位小数结果却有两位或更多的小数时)。
总结
注:使用BigDecimal的坏处是性能比double和float差,在处理庞大,复杂的运算时尤为明显。