assert(0.1 + 0.2 != 0.3); // shall be true
ist meine Lieblingsprüfung, dass eine Sprache native Gleitkomma-Arithmetik verwendet.
C ++
#include <cstdio>
int main()
{
printf("%d\n", (0.1 + 0.2 != 0.3));
return 0;
}
Ausgabe:
1
Python
print(0.1 + 0.2 != 0.3)
Ausgabe:
True
Andere Beispiele
- Java: http://ideone.com/EPO6X
- C #: http://ideone.com/s14tV
Warum gilt das nicht für D? Nach dem Verständnis verwendet D native Gleitkommazahlen. Ist das ein Fehler? Verwenden sie eine bestimmte Zahlendarstellung? Etwas anderes? Ziemlich verwirrend.
D.
import std.stdio;
void main()
{
writeln(0.1 + 0.2 != 0.3);
}
Ausgabe:
false
AKTUALISIEREN
Danke an LukeH . Dies ist ein Effekt von Gleitkommakonstante Folding beschrieben dort .
Code:
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
}
Ausgabe:
false
true