Delphi-PRAXiS
Seite 2 von 3     12 3      

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

DeddyH 9. Mai 2011 15:57

AW: Zeitmessung
 
Im Format-String von FormatDateTime dürfen nur gültige Format-Bezeichner stehen.

Satty67 9. Mai 2011 16:00

AW: Zeitmessung
 
Zitat:

Zitat von loirad (Beitrag 1099773)
start-ende

Wenn schon so, dann ende-start oder besser als Alternative QueryPerformanceCounter nutzen.

Es schwirren hier auch fertige StoppUhr Beispiele rum bzw. gibt es in neueren Delphi-Versionen evtl. sogar eine?

himitsu 9. Mai 2011 16:09

AW: Zeitmessung
 
Ich würde mal ende-start, anstatt start-ende rechnen ... dann kommen da auch keine negativen Werte raus.
(deine positiven Tage/monate/Jahre sind eigentlich durch einen negativen Bereichsüberlauf entstanden)

[edit]
Tschuldschung, hab Seite 2 übersehn :oops:

loirad 9. Mai 2011 16:28

AW: Zeitmessung
 
Auch wenn ich ende und start vertausche kommen die 30 Tage, 12 Monate und 99 Jahre raus. Wie kann ich das verändern :?::?::?:
@ DeddyH: Was meinst du damit?

DeddyH 9. Mai 2011 16:50

AW: Zeitmessung
 
Damit meine ich, dass z.B. bei dem Wort "Jahre" das "h" als Stunde interpretiert und somit geparst wird. Von daher verbieten sich bei FormatDateTime alle Zeichen oder Wörter, die mit der eigentlichen Formatierung nichts zu tun haben.

loirad 9. Mai 2011 17:43

AW: Zeitmessung
 
@ DeddyH: Ich meine ja immer das vor dem Wort ist der Wert!
@ all: Vorschläge zur Vermeidung, dass 30 Tage, 12 Monate und 99 Jahre ausgegeben werden, wenn nichtmal ein Tag vergangen ist?
Ideen wären sehr hilfreich :thumb::thumb::thumb:!!!

himitsu 9. Mai 2011 19:46

AW: Zeitmessung
 
@DeddyH: rte mal, warum er soviele " in dem Text hat ... alles was damit Maskiert ist, wird nicht als Steuerzeichen geparst ... also macht das h in Jahre keine Probleme. :angle:

Und zu den Werten bei Tag/Monat/Jahr ... welchen Wert haben denn die Variablen?

loirad 9. Mai 2011 20:03

AW: Zeitmessung
 
Ich send einfach mal den wichtigen Teil des Quelltextes:

Code:
procedure TForm1.BerechnenClick(Sender: TObject);
var start,ende:tdatetime;
begin
start:=now;
//Quelltext, dessen Zeit gemessen werden soll
ende:=now;
showmessage(SysUtils.FormatDateTime('d" Tage":" "m" Monate":" "y" Jahre":" "h" Stunden":" "n" Minuten":" "s" Sekunden ":" "z" Millisekunden"',ende-start));
end;
(immernoch 30 Tage, 12 Monate und 99 Jahre ausgegeben)
Ideen?

bernerbaer 9. Mai 2011 20:14

AW: Zeitmessung
 
Geht das nicht einfacher, wenn man direkt in milliseconds arbeitet?

Delphi-Quellcode:
var
   start, ende, dauer : Int64;

   datumswert: TDatetime;
 begin
   start := GetTickCount;
   // hier kommt die ganz lange Funktion
   ende := GetTickCount;
   dauer:= ende - start;
   
   
   // und jetzt noch reine Mathematik oder per Format() ins gewünschte Ausgabeformat bringen zb.:

datumswert:= dauer / MSecsPerSec /  SecsPerDay;

showmessage(FormatDateTime('d" Tage":" "m" Monate":" "y" Jahre":" "h" Stunden":" "n" Minuten":" "s" Sekunden ":" "z" Millisekunden"',datumswert));

Wolfgang Mix 9. Mai 2011 20:17

AW: Zeitmessung
 
Zeitstempel aus Post #10 schon gesichtet?


Alle Zeitangaben in WEZ +1. Es ist jetzt 02:14 Uhr.
Seite 2 von 3     12 3      

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