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); };
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.
steinadler Geschrieben 30. März 2006 Autor Geschrieben 30. März 2006 Danke dir Klotzkopp. Hab das gemacht mit dem Runden.
Empfohlene Beiträge
Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren
Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können
Benutzerkonto erstellen
Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!
Neues Benutzerkonto erstellenAnmelden
Du hast bereits ein Benutzerkonto? Melde Dich hier an.
Jetzt anmelden