AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

StrToFloat und FloatToStr

Offene Frage von "HavoC"
Ein Thema von HavoC · begonnen am 12. Sep 2004 · letzter Beitrag vom 14. Sep 2004
Antwort Antwort
HavoC

Registriert seit: 28. Aug 2004
15 Beiträge
 
#1

StrToFloat und FloatToStr

  Alt 12. Sep 2004, 10:55
Ich hab da ein kleines Problem mit FloatToStr und umgekehrt.
Ich arbeite mit folgenden Deklarationen:
Delphi-Quellcode:
type T3dVektor = record
              x1, x2, x3: real;
            end;
...
var PDatei: File of T3dVektor;
Nun hab ich folgendes Problem.
Ich lese Strings aus Edit-Boxen und konvertiere diese mit StrToFloat, dieser Wert wird dann in die Datei geschrieben.
Wenn ich nun aber wieder aus der Datei lese, stellt mir Delphi den Wert nicht als Real da, wie er es tun sollte. StrToFloatF hat mir auch nicht geholfen, da zeigt er mir komischerweise immer 0 an, obwohl der Eintrag in der Datei nen anderen Wert haben dürfte.
Wie bekomme ich also den Float-Wert in nen Real umgewandelt? FloatToDecimal müsste helfen aber ich hab irgendwie keine Beispiele dazu gefunden und Blicke das mit den Parametern da nicht wirklich.

Schonmal danke im Vorraus für eventuelle Hilfe
  Mit Zitat antworten Zitat
Benutzerbild von glkgereon
glkgereon

Registriert seit: 16. Mär 2004
2.287 Beiträge
 
#2

Re: StrToFloat und FloatToStr

  Alt 13. Sep 2004, 19:44
also es heisst immer keinen real benutzen...nutz doch einfach double...

oder hab ich das problkem missverstanden?
»Unlösbare Probleme sind in der Regel schwierig...«
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#3

Re: StrToFloat und FloatToStr

  Alt 14. Sep 2004, 00:09
Zitat von glkbkk:
also es heisst immer keinen real benutzen...nutz doch einfach double...
Ähh, Warum kein real? Wo hast Du das her ?
Gruß
Hansa
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#4

Re: StrToFloat und FloatToStr

  Alt 14. Sep 2004, 00:41
Aus der Hilfe eventuell?
Zitat:
The six-byte Real48 type was called Real in earlier versions of Object Pascal.
[..]
Real48 is maintained for backward compatibility. Since its storage format is not native to the Intel CPU family, it results in slower performance than other floating-point types.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von dizzy
dizzy

Registriert seit: 26. Nov 2003
Ort: Lünen
1.932 Beiträge
 
Delphi 7 Enterprise
 
#5

Re: StrToFloat und FloatToStr

  Alt 14. Sep 2004, 00:49
Aber er nutzt ja nicht Real48 . Das Dingen mit Real ist nur, dass es der gerade auf der CPU/FPU verfügbaren nativen Länge entspricht, und das ist bei aktuellen 64-Bit FPUs nunmal Double. Daher ist in der aktuellen Delphiversion Real=Double.

Ich gebe aber zu, dass ich auch immer Double anstelle von Real nehme, da dann eindeutiger ist, was gemeint ist - auch für Nicht-Delphianer. Aber einen echten Nachteil wird man nicht haben. Wobei man in dem Link (s.u.) auch sieht, dass u.U. Real nicht gleichschnell wie Double ist, da nämlich LongInt und Integer auch unterschiedlich schnell sind, obwohl laut OH identisch .

\\edit: Real48 ist übrigends ca. um den Faktor 20 (bei einer Addition) langsamer als Double. (6. Beitrag v.o.)
Fabian K.
INSERT INTO HandVonFreundin SELECT * FROM Himmel
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#6

Re: StrToFloat und FloatToStr

  Alt 14. Sep 2004, 00:52
Wenn ich die Delphi Hilfe richtig verstanden habe ist Real48 und Real identisch mittlerweile.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von dizzy
dizzy

Registriert seit: 26. Nov 2003
Ort: Lünen
1.932 Beiträge
 
Delphi 7 Enterprise
 
#7

Re: StrToFloat und FloatToStr

  Alt 14. Sep 2004, 00:55
Definitiv nicht! (Bei D7)

Zitat von OH:
Code:
Der generische Typ Real ist in der aktuellen Implementation mit dem Typ Double identisch.

Generische reelle Typen
Typ   Bereich                           Signifikante Stellen   Größe in Byte
Real   5.0 x 10^-324 .. 1.7 x 10^308   15-16                   8
Real48 ist 6 Byte lang.
Fabian K.
INSERT INTO HandVonFreundin SELECT * FROM Himmel
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#8

Re: StrToFloat und FloatToStr

  Alt 14. Sep 2004, 01:29
Was habt ihr mit Real48
Gruß
Hansa
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:33 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz