public static double add(double d1,double d2){
BigDecimal b1=new BigDecimal(Double.toString(d1));
BigDecimal b2=new BigDecimal(Double.toString(d2));
return b1.add(b2).doubleValue();
}
公共静态双子(双 d1,双 d2){
BigDecimal b1=new BigDecimal(Double.toString(d1));
BigDecimal b2=new BigDecimal(Double.toString(d2));
return b1.subtract(b2).doubleValue();
}
公共静态双 mul(双 d1,双 d2){
BigDecimal b1=new BigDecimal(Double.toString(d1));
BigDecimal b2=new BigDecimal(Double.toString(d2));
return b1.multiply(b2).doubleValue();
}
公共静态双 div(双 d1,双 d2){
返回div(d1,d2,DEF_DIV_SCALE);
}
public static double div(double d1,double d2,int scale){
//规模是小数点后要保留的补充
if(scalethrow new IllegalArgumentException(“精度不能小于零”);
}
BigDecimal b1=new BigDecimal(Double.toString(d1));
BigDecimal b2=new BigDecimal(Double.toString(d2));
return b1.divide(b2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();
}
用的时候调用这几个方法。
在大多数情况下,使用double和float计算的结果是准确的,但是在一些对精度要求很高的系统中,这种问题是非常严重的。
在《Effective Java》中提到了一个原则,那就是float和double只能用于作科学计算或者是工程计算,但是在商业计算中我们用到了java.math.BigDecimal,通过使用BigDecimal类可以解决上述问题问题,实例代码如下:
包装前;
导入 java.math.*;
公共类 BigDecimalDemo {
public static void main(String[] args){
System.out.println(ArithUtil.add(0.01, 0.05));
System.out.println(ArithUtil.sub(1.0, 0.42));
System.out.println(ArithUtil.mul(4.015, 100));
System.out.println(ArithUtil.div(123.3, 100));
}
}
类 ArithUtil{
private static Final int DEF_DIV_SCALE=10;
私有 ArithUtil(){}
//相加
public static double add(double d1,double d2){
BigDecimal b1=new BigDecimal(Double.toString(d1));
BigDecimal b2=new BigDecimal(Double.toString(d2));
return b1.add(b2).doubleValue();
}
//相减
公共静态双子(双 d1,双 d2){
BigDecimal b1=new BigDecimal(Double.toString(d1));
BigDecimal b2=new BigDecimal(Double.toString(d2));
return b1.subtract(b2).doubleValue();
}
//相乘
公共静态双 mul(双 d1,双 d2){
BigDecimal b1=new BigDecimal(Double.toString(d1));
BigDecimal b2=new BigDecimal(Double.toString(d2));
return b1.multiply(b2).doubleValue();
}
//相除
公共静态双 div(双 d1,双 d2){
返回div(d1,d2,DEF_DIV_SCALE);
}
public static double div(double d1,double d2,int scale){
如果(规模
抛出 new IllegalArgumentException(“小数位数必须是正整数或零”);
}
BigDecimal b1=new BigDecimal(Double.toString(d1));
BigDecimal b2=new BigDecimal(Double.toString(d2));
return b1.divide(b2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();
}
}
两个int的值作除法侵犯,得到的为int,而且,得到的值是直接去掉小数部分。
假设:
int i=1;j=3;i/j==0 返回为true
同理,i/3==0 1/3==0 1/j==0 都返回为true
如果,double res=i/j 其返回的结果,不会是0.333...,而是0
如果你要得到为0.333...,则需要 res=((double)i)/j;
而你的
fReuslt=(int)((double)num1/num2)
底部先执行num1/num2,如果num1和num2都int,都到的结果最终会是int,这里假设num1=6,num2=5,则num1/num2==1为true,而不是1.2,那么,再执行(double)res,这里的res就是num1/num2,故res=1,所以double之后仍然为1,而不是1.2
以上是如何在JAVA中处理 double 精度问题的详细内容。更多信息请关注PHP中文网其他相关文章!