java中BigDecimal类是如何进行浮点数运算
BigDecimal:不可变的、任意精度的有符号十进制数,可以解决数据丢失问题。
说BigDecimal之前先给大家看一段代码
class test{
public static void main(String[] args){
System.out.println(0.09 + 0.01);//0.09999999999999999
System.out.println(1.0 - 0.32);//0.6799999999999999
System.out.println(1.015 * 100);//101.49999999999999
System.out.println(1.301 / 100);//0.013009999999999999
System.out.println(1.0 - 0.12); //0.88
}
}
- 如果直接输出则会出现数据精度丢失的问题,这是因为float类型的数据存储和整数不一样导致的。它们大部分的时候,都是带有有效数字位。
- 由于在运算的时候,float类型和double很容易丢失精度,演示案例。所以,为了能精确的表示、计算浮点数,Java提供了BigDecimal
通过API我们知道,BigDecimal需要导包 import java.util.BigDecimal;
构造方法:
- public BigDecimal(String val)
方法:
- public BigDecimal add(BigDecimal augend);加
- public BigDecimal subtract(BigDecimal subtrahend);减
- public BigDecimal multiply(BigDecimal multiplicand);乘
- public BigDecimal divide(BigDecimal divisor);除
- public BigDecimal divide(BigDecimal divisor,int scale,int roundingMode):商,几位小数,如何舍取
import java.util.BigDecimal;
class test{
public static void main(String[] args){
BigDecimal bd1 = new BigDecimal("0.01");
BigDecimal bd2 = new BigDecimal("0.09");
System.out.println("add:"+bd1.add(bd2));
//输出结果为:add:0.10
BigDecimal bd1 = new BigDecimal("1.0");
BigDecimal bd2 = new BigDecimal("0.32");
System.out.println("subtract:"+bd1.subtract(bd2));
//输出结果为:subtract:0.68
BigDecimal bd1 = new BigDecimal("1.015");
BigDecimal bd2 = new BigDecimal("100");
System.out.println("multiply:"+bd1.multiply(bd2));
//输出结果为:multiply:101.500
BigDecimal bd1 = new BigDecimal("1.301");
BigDecimal bd2 = new BigDecimal("100");
System.out.println("divide:"+bd1.divide(bd2));
//输出结果为:divide:0.01301
BigDecimal bd1 = new BigDecimal("1.301");
BigDecimal bd2 = new BigDecimal("100");
System.out.println("divide:"+bd1.divide(bd2,3,BigDecimal.ROUND_HALF_UP));
//3代表的就是小数点后面的有三位
//输出结果为:divide:0.013
BigDecimal bd1 = new BigDecimal("1.301");
BigDecimal bd2 = new BigDecimal("100");
System.out.println("divide:"+bd1.divide(bd2,8,BigDecimal.ROUND_HALF_UP));
//多的后面补零
//输出结果为:divide:0.01301000
}
}