left,right是两个String类型的字符串,myres是一个double类型的变量。
如果我们用下面的语句把left,right先转换为double后直接加法的话,如果作3.3乘3之类的运算(被乘数是奇数会出问题),会变成9.8888888889,而不是我们想要的9.9,这就是精度缺失。
myres=Double.valueOf(left)+Double.valueOf(right);
解决方法:
double lt=Double.parseDouble(left);
double rt=Double.parseDouble(right);
BigDecimal b1 = new BigDecimal(Double.toString(lt));
BigDecimal b2 = new BigDecimal(Double.toString(rt));
加法
myres=b1.add(b2).doubleValue();
return myres;
减法
myres=b1.subtract(b2).doubleValue();
return myres;
乘法
myres=b1.multiply(b2).doubleValue();
return myres;
除法
myres=b1.divide(b2).doubleValue();
return myres;
返回的myres是正确的结果,这个也可以应用于Android开发过程中。