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)
有人想解释这里发生了什么吗?我猜这与int
s冒充float
s的整数运算有关.此外,还有其他基地(除了10
)有这个属性?
1.0具有精确的二进制表示.0.1没有.
也许你在问为什么0.1没有存储为1的尾数和-10的指数?但这不是它的工作原理.它不是十进制数加上指数,而是二进制数.所以"时代10"并不是一件很自然的事情.
对不起,也许最后一部分不清楚.最好将指数视为位的移位.没有位移位会将无限序列(如0.1(十进制))转换为有限序列.
归档时间: |
|
查看次数: |
1720 次 |
最近记录: |