引文:
BigDecimal的使用方法
一、基本使用
// 1、创建BigDecimal类型数据
//(1) 通过构造方法创建
public BigDecimal(String val);
public BigDecimal(double val);
public BigDecimal(int val);
public BigDecimal(long val);
//(2) 通过静态方法创建
BigDecimal.valueOf()
//(2) 方法使用
public BigDecimal add(BigDecimal augend);//加法
public BigDecimal subtract(BigDecimal subtrahend);//减法
public BigDecimal multiply(BigDecimal multiplicand);//乘法
public BigDecimal divide(BigDecimal divisor, int roundingMode);//除法
public BigDecimal setScale(int newScale, RoundingMode roundingMode);
//newScale小数点后面保留位数,roundingMode取舍方式;
//取舍方式:
//ROUND_HALF_UP 四舍五入
//ROUND_CEILING 向正无穷方向舍入
//ROUND_DOWN 向零方向舍入
//ROUND_FLOOR 向负无穷方向舍入
//ROUND_HALF_DOWN 向(距离)最近的一边舍入
//设置精度
public int compareTo(BigDecimal val);//比较
//3、输出
public double doubleValue();//输出
二、注意点
// 1、使用BigDecimal的double类型构造函数转化,不精确。
BigDecimal bg = new BigDecimal(0.1);
System.out.println(bg);
// 解决方案:
//1). 先将double val 转为String类型,再使用BigDecimal的String类型构造函数
BigDecimal bg= new BigDecimal(String.valueOf(val));
//2). 使用BigDecimal的double类型valueOf()方式
BigDecimal bg= BigDecimal.valueOf(val);
//3).先对double类型数据进行格式化,然后再转化:
DecimalFormat df = new DecimalFormat("###0.00");//保留两位小数
BigDecimal bg= new BigDecimal(df.format(val));
//2、除法报错:Non-terminating decimal expansion; no exact representable decimal result
foo.divide(bar));
//解决
foo.divide(bar,2,BigDecimal.ROUND_HALF_UP));