double和float不能进行精确计算,商业计算经常使用BigDecimal进行精确计算。
1. 创建BigDecimal类型数据
使用构造方法:
可将基本类型数据、String类型(可转为基础类型的)、bigInteger等类型通过BigDecimal构造函数方式转为BigDecimal类型数据。
public BigDecimal(String val);
public BigDecimal(double val);
public BigDecimal(int val);
public BigDecimal(long val);
使用BigDecimal.valueOf()方法:
public static BigDecimal valueOf(double val);
将double类型数据转为BigDecimal类型:
使用BigDecimal的double类型构造函数转化,结果不精确:
BigDecimal bg = new BigDecimal(0.1);
System.out.println(bg);
期望输出:0.1
实际输出:0.1000000000000000055511151231257827021181583404541015625
为了得到精确值,double转为BigDecimal类型,使用以下三种方法:
1). 先将double val 转为String类型,再使用BigDecimal的String类型构造函数
BigDecimal bg= new BigDecimal(String.valueOf(val));
2). 使用BigDecimal的double类型valueOf()方式
BigDecimal bg= BigDecimal.valueOf(val);
3).先对double类型数据进行格式化,然后再