![]() |
TDateTime kann nicht korrekt verglichen werden
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo zusammen!
Nachdem ich schon wieder ernsthaft an mir selbst gezweifelt habe, bin ich doch langsam am Überlegen, ob das Folgende nicht vielleicht doch ein Delphi-Bug sein könnte: Vorab: Ich lasse alle TDateTime-Werte * Sekunden pro Tag nehmen (nur den Nachkommateil natürlich), um die Anteiligen Sekunden zu ermitteln (gerundet) und teile dies dann wieder durch die Sekunden pro Tag. Das hat den Vorteil, dass ich diese TDateTime-Werte immer auf die volle Sekunde gerundet habe, damit ich beim Vergleichen keine Abweichungen oder Fehler durch z.B. Millisekunden habe. Leider kommt es manchmal vor, dass Delphi irgendwie scheinbar zu ungenau Arbeitet. Auf dem beigelegten Screenshot kann man folgendes sehen: Wir befinden uns in einer meiner Prozeduren. (Die Variablen sind alle nur für diesen Screenshot erstellt, also bitte nicht wegen der Benennung meckern :stupid:) u.a.:
Delphi-Quellcode:
_NextFromDateTime ist ein TDateTime-Wert, welcher der Prozedur übergeben wird. Er soll im Laufe der Prozedur mit dt verglichen werden.
var
dt: TDateTime; dtErsterDesMonats: TDateTime; a, b: TDateTime; e, f: string; t: string; Am Haltepunkt auf dem Screenshot sehen wir in der Liste der überwachten Ausdrücke und lokalen Variablen, dass dt == _NextFromDateTime ist. Sowohl als Double, Float und String. Lediglich die TDateTime-Werte unterscheiden sich scheinbar(!) da z.B. (a = b) und (dt = _NextFromDateTime) jeweils False ergibt. In der Auswertung werden TDateTime-Werte jedoch ausschließlich als String angezeigt (dd.mm.yyyy HH:nn), was sich auch beim Umschalten auf "Gleitkomma" o.ä. bei den überwachten Ausdrücken nicht ändert! Tja, und nun? 1) Wie kann ich beim Debuggen sehen, welchen (Gleitkommawert) die beiden TDateTime-Variablen haben? Der Typcast als Float oder Double gibt beide ja als identisch aus? 2) Wie kann ich TDateTime-Werte möglichst einfach korrekt vergleichen 3) , so dass höchstens die Sekunden, nicht aber Millisekunden vergleichen werden? Danke schonmal. :/ |
AW: TDateTime kann nicht korrekt verglichen werden
Mal kurz drei Möglichkeiten:
|
AW: TDateTime kann nicht korrekt verglichen werden
Ich denke, dass es tatsächlich an den Rundungsdifferenzen liegen kann.
Schau mal in die Unit DateUtils. Dort sind Vergleichsfunktionen für Datum drin. Ich meine, dass die dort sogar, etwas Source gegen die Rundungsdiffs haben. Im Zweifelsfall einfach dein Datum nehmen, mit Sekunden am Tag multiplizieren und mit trunc() in Integer wandeln und diesen vergleichen. |
AW: TDateTime kann nicht korrekt verglichen werden
Zitat:
|
AW: TDateTime kann nicht korrekt verglichen werden
Das scheinen durchaus sinnvolle und umsetzbare Lösungansätze zu sein.
Vielen Dank! Hat noch jemand eine Idee bzgl. der Anzeige in der Liste überwachter Ausdrücke? |
AW: TDateTime kann nicht korrekt verglichen werden
Hallo
ich würde folgendes tun... Zitat:
Code:
OutputDebugString(pchar(FormatDateTime('dd.mm.yyyy hh:nn:ss.zzz', now)));
Zitat:
Code:
uses DateUtils;
if SecondsBetween(now, then)=0 then... |
AW: TDateTime kann nicht korrekt verglichen werden
Zur Info:
Delphi-Quellcode:
Liefert jeweils 100% identische Werte, obwohl -wie erwähnt- dies Werte unterschiedlich sind.
OutputDebugString(pchar(FormatDateTime('dd.mm.yyyy hh:nn:ss.zzz', a)));
OutputDebugString(pchar(FormatDateTime('dd.mm.yyyy hh:nn:ss.zzz', b))); OutputDebugString(pchar(FormatDateTime('dd.mm.yyyy hh:nn:ss.zzz', dt))); OutputDebugString(pchar(FormatDateTime('dd.mm.yyyy hh:nn:ss.zzz', _NextFromDateTime))); SecondsBetween scheint der allereinfachste Lösungsansatz zu sein. Danke :) |
AW: TDateTime kann nicht korrekt verglichen werden
Thema vorläufig erledigt. Danke :) (Muss man Antworten, um "Offene Frage" herauszunehmen?)
|
AW: TDateTime kann nicht korrekt verglichen werden
Einen "Nachtrag" noch, da ich leider den letzten Eintrag nicht mehr bearbeiten kann:
Mir ist gerade ein uralter Trick eingefallen, mit dem ich vor langer Zeit schonmal ein änhliches Problem gelöst/umgangen habe:
Delphi-Quellcode:
NeuerDateTimeWert := StrToDateTime(DateTimeToStr(AlterDateTimeWert));
"Erschreckend" an der Sache ist, dass Delphi aus AlterDateTimeWert = 05.01.2011 10:52:11 --> NeuerDateTimeWert = 05.01.2011 10:52:10 macht. (Rundungsproblematik beachten! laut Überwachung lokaler Variablen) Identisch ist natürlich in der Überwachung: DateTimeToStr(AlterDateTimeWert) = '05.01.2011 10:52:11' und StrToDateTime(DateTimeToStr(AlterDateTimeWert)) = 05.01.2011 10:52:10. Somit scheint Delphi bei der Darstellung von "nicht runden" TDateTimeWerten in der überwachung lokaler Variablen und Liste überwachter Ausdrücke NICHT die Funktion DateTimeToStr() zu benutzen, sondern etwas selbstgebasteltet. Finde ich persönlich für gescheites Debuggen sehr, sehr fragwürdig, denn man sollte schon erwarten können, dass der menschenlesbare Wert von TDateTime identisch ist mit DateTimeToStr() eben dieses Wertes... Feedback dazu erwünscht, vielleicht mache ja ich was falsch. Ansonsten: sollte man das mal wirklich als Delphi-Bug posten? |
AW: TDateTime kann nicht korrekt verglichen werden
Es ist doch dein Problem, dass du einen Floatwert direkt vergleicht. Man muss entweder Bereiche festlegen, oder das nach dem Komma abschneiden. Oder liefert dir SQRT(2) einen exakten Wert.
Das ist kein Delphi-Bug |
Alle Zeitangaben in WEZ +1. Es ist jetzt 15:27 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz