steinadler Geschrieben 30. März 2006 Teilen 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 Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Klotzkopp Geschrieben 30. März 2006 Teilen 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 Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
steinadler Geschrieben 30. März 2006 Autor Teilen Geschrieben 30. März 2006 Danke dir Klotzkopp. Hab das gemacht mit dem Runden. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
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.