java中0.01,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 ,并保留分值。

链接地址: http://www.djcxy.com/p/85801.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值