public class UseCase {
public static BigDecimal div(double value1,double value2,int b,int r){
if(b<0){
System.out.println("b值必须大于等于0");
}
BigDecimal b1=new BigDecimal(Double.toString(value1));
BigDecimal b2=new BigDecimal(Double.toString(value2));
/*为什么要用toString()方法将double值表示为字符串对象*/
return b1.divide(b2,b,r);
}
public static void main(String[] args) {
// TODO 自动生成方法存根
UseCase u=new UseCase();
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_CEILING));
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_DOWN));
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_FLOOR));
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_HALF_DOWN));
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_HALF_EVEN));
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_HALF_UP));
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_UP));
}
}
toString是带有四舍五入的,BigDecimal直接从double获取不会四舍五入,主要就是这个区别。
更精确也更安全些..
https://zhidao.baidu.com/question/114546778.html
BigDecimal新建对象可以是以下四种类型,int,double,long,String。你的2个value值可以是四种类型的任意一种,没必要转成字符类型。
主要是toString会四舍五入,避免了一些浮点数精度问题