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

上一篇: Java Double value = 0.01 changes to 0.009999999999999787

下一篇: Exact solutions for lib(ic)