关于在Android或Java中精度缺失的解决方法

时间:2021-05-28 11:14:37

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开发过程中。