Java中的双重算术和相等

Pen*_*One 1 java floating-point double floating-accuracy ieee-754

这是一个奇怪的事(至少对我来说).此例程打印为true:

double x = 11.0;
double y = 10.0;
if (x-y == 1.0) {
    // print true
} else {
    // print false
}
Run Code Online (Sandbox Code Playgroud)

但是这个例程打印错误:

double x = 1.1;
double y = 1.0;
if (x-y == 0.1) {
    // print true
} else {
    // print false
}
Run Code Online (Sandbox Code Playgroud)

有人想解释这里发生了什么吗?我猜这与ints冒充floats的整数运算有关.此外,还有其他基地(除了10)有这个属性?

and*_*oke 9

1.0具有精确的二进制表示.0.1没有.

也许你在问为什么0.1没有存储为1的尾数和-10的指数?但这不是它的工作原理.它不是十进制数加上指数,而是二进制数.所以"时代10"并不是一件很自然的事情.

对不起,也许最后一部分不清楚.最好将指数视为位的移位.没有位移位会将无限序列(如0.1(十进制))转换为有限序列.