AGB  ·  Datenschutz  ·  Impressum  







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

Date Vergleich

Ein Thema von mcbain · begonnen am 25. Mär 2014 · letzter Beitrag vom 26. Mär 2014
Antwort Antwort
Seite 2 von 2     12   
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.484 Beiträge
 
Delphi 12 Athens
 
#11

AW: Date Vergleich

  Alt 25. Mär 2014, 18:51
Ich glaub den Bug hat man inzwischen sogar "schon" behoben. (in irgendeinem der XEs)
Aber nicht in XE5:

Delphi-Quellcode:
function TCommonCalendar.GetDate: TDate;
begin
  Result := TDate(FDateTime);
end;

function TDateTimePicker.GetTime: TTime;
begin
  Result := TTime(FDateTime);
end;
Insofern bekommt man faktisch dasselbe Ergebnis über Date, Time oder DateTime.

Interessanterweise wird beim Setzen dieser beiden Properties nur jeweils die Date- bzw. Time-Komponente des Werts übernommen. Die jeweils andere bleibt unverändert.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.184 Beiträge
 
Delphi 12 Athens
 
#12

AW: Date Vergleich

  Alt 25. Mär 2014, 19:00
*durchstreich*
Ich war mir ganz sicher, daß es schonmal ging. (ich hoffe nur, ich bin da nicht mit DevExpress durcheinandergekommen ... die haben/hatten auch solche Bugs)


Zitat:
Möglicherweise hat man sich später nicht mehr getraut diesen Bug abzustellen weil dies existierenden Code brechen könnte...
Hier würde ich das ja einfach hart abändern, so daß es nun richtig geht.
Oder man fängt mit Properties an, die sich plötzlich RealDate und RealTime nennen, oder so.

Aber da es hier auch das .DateTime gibt und somit keine Funktion verloren geht, haben einfach die Pech gehabt, die es bisher falsch gemacht haben.


Jetzt müsste man nur mal nachsehn, ob es nicht schon einen QC dafür gibt.
$2B or not $2B
  Mit Zitat antworten Zitat
Popov
(Gast)

n/a Beiträge
 
#13

AW: Date Vergleich

  Alt 25. Mär 2014, 20:17
Theoretisch darf es keine Rundungsfehler geben, aber bei Millisekunden ist man da anscheinend nicht so genau. TDateTime ist ja nur eine Zahl, was vor dem Komma ist, sind Tage, nach dem Komma die Stunden, Minuten, Sekunden und Millisekunden.

Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var
  h, n, s, ms: Integer;
  t: TDateTime;
  d: Double;
begin
  t := EncodeTime(11, 20, 30, 998);

  d := t * 24;
  h := Trunc(d);

  d := (d - h) * 60;
  n := Trunc(d);

  d := (d - n) * 60;
  s := Trunc(d);

  d := (d - s) * 1000;
  ms := Trunc(d);

  //ShowMessage('Zeit: ' + TimeToStr(t));
  ShowMessage(Format('h: %d, n: %d, s: %d, ms: %d', [h, n, s, ms]));
end;
Bei der Millisekunde wird es ungenau im 1/1000 Sekunde.
  Mit Zitat antworten Zitat
Furtbichler
(Gast)

n/a Beiträge
 
#14

AW: Date Vergleich

  Alt 26. Mär 2014, 07:43
Theoretisch darf es keine Rundungsfehler geben
Theoretisch darf es natürlich Rundungsfehler geben. Praktisch gibt es sie ja auch. Das liegt an der Natur des 'Double'.
...nicht alle Werte können wirklich korrekt dargestellt werden...
Bei ganzen Zahlen (also nur das Datum z.B.) stimmt das nicht, diese werden genau angegeben. Daher wundert es mich ein wenig. Oder anders ausgedrückt: Ich wäre auch drauf reingefallen.

PS: Im Datenbankbereich gibt es diese Probleme interessanterweise nicht, obwohl man annehmen kann, das ein DateTime auch als Double gespeichert wird. Ergo stimmt diese Annahme nicht, denn
Code:
WHERE myDateTimeColumn BETWEEN @SomeDate and @SomeOtherDate
  or (myOtherDateTimeColumn => @SomeDate and myOtherDateTimeColumn <= @SomeOtherDate)
funktioniert immer. In der Tat wird ein DateTime zumindest im SQL-Server als INTEGER-INTEGER abgelegt (8 Bytes), wobei die erste Zahl die Anzahl der Tage seit 1.1.1900 und die Zweite Zahl die Anzahl der Ticks seit Mitternacht angibt, wobei hier blöderweise 300 Ticks = 1 sec ist, womit wieder eine Ungenauigkeit eingeführt wird, da man die letzte ms-Stelle mal wieder nicht genau treffen kann.

Irgendwie habens die Informatiker mit Ungenauigkeiten.

Geändert von Furtbichler (26. Mär 2014 um 07:53 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.184 Beiträge
 
Delphi 12 Athens
 
#15

AW: Date Vergleich

  Alt 26. Mär 2014, 08:09
Und je öfter man "nacheinander" rechnet, um so mehr können/werden sich Rundungsfehler "aufsummieren".
$2B or not $2B
  Mit Zitat antworten Zitat
Furtbichler
(Gast)

n/a Beiträge
 
#16

AW: Date Vergleich

  Alt 26. Mär 2014, 10:21
Und je öfter man "nacheinander" rechnet, um so mehr können/werden sich Rundungsfehler "aufsummieren".
Wenn Du nicht gerade sehr kleine mit sehr großen Zahlen miteinander multiplizierst, ist das irrelevant. Aber die Thematik ist gefühlte 1.000.000,00000000000128 (double halt) mal durchgekaut.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 12:33 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 by Thomas Breitkreuz