Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Multimedia (https://www.delphipraxis.net/16-multimedia/)
-   -   Zeitmessung (https://www.delphipraxis.net/160351-zeitmessung.html)

loirad 9. Mai 2011 15:07

Zeitmessung
 
Hallo liebe Delphi-PRAXISler,

ich messe die Zeit, zwischen 2 Zeiten so :arrow:
Code:
start:=now;
Startzeit.Caption:='Startzeit: '+timetostr(start); //(Label Startzeit)
//Prozedure, von der die Zeit gemessen werden soll
ende:=now;
Endzeit.Caption:='Endzeit: '+timetostr(ende); //(Label Endzeit)
Dauer.Caption:='Dauer: '+timetostr(start-ende); //(Label Dauer)
Jetzt ist mein Problem, dass manchmal (nicht immer) einfach 1 Sekunde zu wenig bei dem Label Dauer angezeigt wird. Wo sitzt da der Fehler :?: Hat jemand eine Idee :idea: ?

Mit freundlichen Grüßen
loirad

Satty67 9. Mai 2011 15:12

AW: Zeitmessung
 
Rundungsproblem?

TDateTime ist ja ein Double, der auch Millisekunden beinhaltet.

loirad 9. Mai 2011 15:23

AW: Zeitmessung
 
kann man die Millisekunden auch anzeigen? - wenn ja wie?

DeddyH 9. Mai 2011 15:26

AW: Zeitmessung
 
Delphi-Referenz durchsuchenFormatDateTime

Wolfgang Mix 9. Mai 2011 15:28

AW: Zeitmessung
 
Teile die Nachkommastelle durch 3600 und zeige das dann an

himitsu 9. Mai 2011 15:30

AW: Zeitmessung
 
TimeToStr rundet ab, wobei dann natürlich schnell mal was "fehlen" kann.

Mit einer Sekunde differenz kann man aber eigentlich noch Leben.
Du könntest jetzt auch einfach mal 0.0003472 ('ne halbe Sekunde) zur ausgerechneten Differenz dazuaddieren, dann wird da seltener Abgerundet, aber dafür könnte es ab nun auch mal eine Sekunde zuviel sein.

Wenn du es wirklich genau brauchst, also die Differenz der angezeigten Werte,
dann wirst du ebenfalls jeweils die Anfangs- und Endzeit auf ganze Sekunden abrunden müssen und danach kannst du die gewünschte Differenz ausrechnen.

Wolfgang Mix 9. Mai 2011 15:34

AW: Zeitmessung
 
Der Fehler liegt dann wohl nicht im Sekunden-, sondern im Millisekundenbereich. Auch damit wird man leben können :-)

rollstuhlfahrer 9. Mai 2011 15:43

AW: Zeitmessung
 
Zitat:

Zitat von Wolfgang Mix (Beitrag 1099757)
Teile die Nachkommastelle durch 3600 und zeige das dann an

Sollte das nicht "multipliziere" heißen?

Bernhard

loirad 9. Mai 2011 15:48

AW: Zeitmessung
 
Wenn ich mir da dann Tage, Monate und Jahre anzeige, dann werden mir dort andere Zahlen ausgegeben.
Hier ein Beispiel :arrow: "30 Tage: 12 Monate: 99 Jahre: 0 Stunden: 0 Minuten: 8 Sekunden: 979 Millisekunden"
Code:
showmessage(SysUtils.FormatDateTime('d" Tage":" "m" Monate":" "y" Jahre":" "h" Stunden":" "n" Minuten":" "s" Sekunden ":" "z" Millisekunden"',start-ende));
Das Programm hat aber keinen Tag gedauert.
Woran liegt das?
Liegt das an dem "now"?
Wie kann ich das ändern?

Wolfgang Mix 9. Mai 2011 15:56

AW: Zeitmessung
 
Liste der Anhänge anzeigen (Anzahl: 1)
Schaue dir mal dieses Projekt an (Anhang)


Alle Zeitangaben in WEZ +1. Es ist jetzt 15:08 Uhr.
Seite 1 von 3  1 23      

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