Java Double value = 0.01更改为0.009999999999999787
可能重复:
为什么不使用Double或Float来表示货币?
我正在为我的高中课程编写一个基本的Java命令行程序。 我们现在只使用变量。 它用于计算购买后更改的任何类型的账单和硬币数量。 这是我的程序:
class Assign2c {
public static void main(String[] args) {
double cost = 10.990;
int paid = 20;
double change = paid - cost;
int five, toonie, loonies, quarter, dime, nickel, penny;
five = (int)(change / 5.0);
change -= five * 5.0;
toonie = (int)(change / 2.0);
change -= toonie * 2.0;
loonies = (int)change;
change -= loonies;
quarter = (int)(change / 0.25);
change -= quarter * 0.25;
dime = (int)(change / 0.1);
change -= dime * 0.1;
nickel = (int)(change / 0.05);
change -= nickel * 0.05;
penny = (int)(change * 100);
change -= penny * 0.01;
System.out.println("$5 :" + five);
System.out.println("$2 :" + toonie);
System.out.println("$1 :" + loonies);
System.out.println("$0.25:" + quarter);
System.out.println("$0.10:" + dime);
System.out.println("$0.05:" + nickel);
System.out.println("$0.01:" + penny);
}
}
它应该都可以工作,但是在最后一步,当剩下0.01美元时,便士的数量应该是1,而相反,它是0.在几分钟后进入代码并将改变值输出到控制台后,我发现在最后一步更改= 0.01时,它将更改为0.009999999999999787。 这是为什么发生?
对货币使用double
是个不错的主意,为什么不使用Double或Float来表示货币? 我建议使用BigDecimal
或每BigDecimal
进行一次计算。
0.01在浮点上没有确切的表示(对于这个问题,也没有0.1或0.2)。
你可能应该用整数类型来做所有的数学运算,这代表了便士的数量。
doubles
不是内部保存在十进制中,而是二进制。 他们的存储格式相当于“ 100101
乘以10000
”(我正在简化,但这是最基本的想法)。 不幸的是,这些二进制值的组合不是完全精确到0.01,这是其他答案在他们说浮点数不是100%准确时的意思,或者0.01在浮点数中没有精确表示点。
处理这个问题有多种方式,比其他方法更复杂。 在你的情况下,最好的解决方案可能是在所有地方都使用int
,并保留分值。
上一篇: Java Double value = 0.01 changes to 0.009999999999999787