Fakt ist es gibt spezielle Compiler-Konstanten mit einer Divison durch Null.
NaN (not a number) = 0.0/0.0;
Infinity = 1.0/0.0;
-Infinity = -1.0/0.0;
Weiss jetzt nicht, wo die definiert sind und wie der richtige Name ist. Aber es gibt sie.
Versucht mal folgendes:
Delphi-Quellcode:
var
test : double;
begin
test:=0.0/0.0; // Hier kommt kein Fehler
ShowMessage(IntToStr(trunc(test)); // hier sollte jetzt Ungültige Gleitkommaoperation kommen
Es hängt davon ab, wie die FPU eingestellt ist. Nicht jedem Fall wird eine EDivisionZero ausgelöst.
Wenn du dagegen StrToFloat machst, dann dürfte sogar NaN erscheinen anstatt eine Ungültige Gleitkommaoperation. Man muss einfach mal damit etwas rumspielen. Fakt ist, dass ich massive Probleme damit habe, weil einfach die Behandlung durch die FPU nicht konsequent genug ist. Oft habe ich schon Ungültige Gleitkommaoperationen gehabt, weil an ganz anderer Stelle (die man nicht ohne weiteres findet), Divisionen durch 0 gemacht wurden.
P.S: Ich hoffe mein Beispiel funktioniert so. Zumindestens ist es bei Delphi 5 so.