steinadler Geschrieben 30. März 2006 Geschrieben 30. März 2006 Hi @all, kann mir jemand sagen, warum das hier nicht geht??? Ich möchte aus einem Float zwei Integers bekommen, und zwar, einen für den Vorkommateil und einen für Nachkomma. Allerdings wenn mein Nachkommateil im Float z.B. 48 ist, dann macht der bei folgender Funktion ein 479999 draus... und deshalb bringt mir die Funktion als Nachkommawert eine 47. SplitFl Element::GetZuzSpl() { int _bc, _ac; // cut after comma _bc = (int)this->flPosZuzahlung; _ac = (int)(((this->flPosZuzahlung) - _bc) * 100); char text[128]; sprintf(text, "%i , %i", _bc, _ac); MessageBox(NULL, text, "Test", 0); }; Zitieren
Klotzkopp Geschrieben 30. März 2006 Geschrieben 30. März 2006 Das ist eine Eigenschaft aller Fließkommatypen. In float und double passen nur ganz bestimmte Werte hinein, und wenn du einen Wert ablegen willst, der nicht genau passt, wird der nächstliegende passende Wert benutzt. Der liegt in deinem Fall knapp unter dem gewünschten Wert - er könnte auch darüber liegen. Du könntest auf zwei Stellen nach dem Komma runden, indem du 0.005 addierst. Oder du könntest gleich Hundertstel speichern und Ganzzahltypen benutzen, falls der Wertebereich ausreicht. Zitieren
steinadler Geschrieben 30. März 2006 Autor Geschrieben 30. März 2006 Danke dir Klotzkopp. Hab das gemacht mit dem Runden. Zitieren
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.