Veröffentlicht 30. März 200619 j 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); };
30. März 200619 j 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.
Archiv
Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.