assert(0.1 + 0.2 != 0.3); // shall be true
- моя любимая проверка того, что язык использует собственную арифметику с плавающей запятой.
С++
#include <cstdio>
int main()
{
printf("%d\n", (0.1 + 0.2 != 0.3));
return 0;
}
Вывод:
1
Python
print(0.1 + 0.2 != 0.3)
Вывод:
True
Другие примеры
Почему это не так для D? Понятно, что D использует собственные числа с плавающей запятой. Это ошибка? Используют ли они какое-то определенное числовое представление? Что-то другое? Довольно запутанный.
D
import std.stdio;
void main()
{
writeln(0.1 + 0.2 != 0.3);
}
Вывод:
false
UPDATE
Благодаря LukeH. Это эффект Floating Point Constant Folding, описанный там.
код:
import std.stdio;
void main()
{
writeln(0.1 + 0.2 != 0.3); // constant folding is done in real precision
auto a = 0.1;
auto b = 0.2;
writeln(a + b != 0.3); // standard calculation in double precision
}
Вывод:
false
true