![]() |
Delphi-Version: XE2
CompareDateTime unter XE2 deutlich langsamer als D2009
Huhu,
ich bin dabei zu prüfen, ob sich ein bestehendes, recht großes Projekt, problemlos von D2009 auf XE2 übertragen lässt. Größtenteils funktioniert alles problemlos, nur an ein, zwei Stellen habe ich bemerkt, dass das unter XE2 kompilierte Programm spürbar langsamer ist als die bisherige, unter D2009 kompilierte Version. Ich habe zunächst alles mögliche vermutet (erstellen/freigeben von Objekten wegen der erweiterten RTTI oder so), aber letztlich scheint es darauf hinaus zu laufen, dass die Funktion CompareDateTime viel, viel langsamer arbeitet als in D2009. Folgendes Codestück - was letztlich eine binäre Suche umsetzt - habe ich mit einer Perfomance-Messung versehen:
Delphi-Quellcode:
Hier ist zu sehen: außer dem CompareDateTime passiert zwischen den beiden QueryPerformanceCounter nicht viel. Der Wert im alten D2009 liegt - nachdem diese Stelle diverse Male aufgerufen wurde - bei ~ 468.000, bei XE2 hingegen bei 3.787.000, D2009 führt die selbe Operation also achtmal so schnell aus.
// Suchschleife
while (not found) and (lowerBound<=upperBound) do begin middle:=round((lowerBound+upperBound)/2); currZu:=TmyDataZushlag(Items[middle]); QueryPerformanceCounter(timeQueryStart); // Vergleich durchführen if compareDateTime(searchTime,currZu.from)=LessThanValue then upperBound:=middle-1 else if compareDateTime(searchTime,currZu.till)=GreaterThanValue then lowerBound:=middle+1 else found:=true; QueryPerformanceCounter(timeQueryStop); timeIsInactiveTimeBin:=timeIsInactiveTimeBin+(timeQueryStop-timeQueryStart); end; Leider habe ich für den Test nur die Trial von XE2, also kann ich nicht in den Quellcode von CompareDateTime gucken, was da geändert wurde. Wenn ich aber die bisherige D2009-Umsetzung von CompareDateTime nachprogrammiere und statt der XE2-Umsetzung benutze, erhalte ich wieder ungefähr die Performance von D2009. Was wurde denn da geändert? Gibt es einen "offiziellen" Weg, das alles wieder schneller zu machen, oder muss ich meine eigene Funktion nutzen, wenn ich es schnell haben will? Bis denn Bommel |
AW: CompareDateTime unter XE2 deutlich langsamer als D2009
Da wurde etwas "akatemischer" umgesetzt.
Wenn diese Funktion wirklich so wichtig ist nimm die D2009-implementierung und gut ist. |
AW: CompareDateTime unter XE2 deutlich langsamer als D2009
PS : in der XE2 Roadshow haben die EMBARCADERO JUNGS mit den Compiler Schaltern bei XE 2 rumgespielt, da kam dann ordentlich mehr Leistung raus bei einer Apfelmännchenberechnung , wie genau -> vergessen :-(
|
AW: CompareDateTime unter XE2 deutlich langsamer als D2009
Ja, bei diesem Compiler-Schalter ({$EXCESSPRECISION ON/OFF}) ging es um den 64-bit Compiler und die Art, wie er Fließkommazahlen von Typ "Single" behandelt.
Hier scheint es sich lt. Bernhard um einen völlig anderen Code zu handeln, der möglicherweise noch diverse Rand- und Rahmenbedingungen berücksichtigt und zwei Daten auch dann korrekt vergleichen kann, wenn Vollmond ist und die Preise für Treibhauskartoffeln gleichzeitig unter 1,50 EUR pro Kilo liegen. Ich fürchte, dass man hier mit den Compiler-Schaltern wenig wird ausrichten können. |
AW: CompareDateTime unter XE2 deutlich langsamer als D2009
Hallo,
man lese und staune: ![]() Zitat:
Aber man kann sich selbst eine solche Funktion schreiben, die diese Umrechnung nicht macht. Gruß Horst |
AW: CompareDateTime unter XE2 deutlich langsamer als D2009
Ich gehe mal stark davon aus, dass D2009 das auch schon getan hat. Sonst gäbe es für die Funktion keine Berechtigung, und ein
Delphi-Quellcode:
wäre gleichwertig (und gleichermaßen fahrlässig). Da muss noch mehr anders sein, mangels XE(2) kann ich das aber leider nicht genauer angeben. Die genannte Tatsache an sich halte ich aber für unwahrscheinlich.
if DateTime1=DateTime2 then ...
|
AW: CompareDateTime unter XE2 deutlich langsamer als D2009
Hallo,
in freepascal läuft es so:
Delphi-Quellcode:
Das wäre ja leicht zu testen, ob es so wieder schneller wäre
{dateih.inc}
const HoursPerDay = 24; MinsPerHour = 60; SecsPerMin = 60; MSecsPerSec = 1000; MinsPerDay = HoursPerDay * MinsPerHour;//1440 SecsPerDay = MinsPerDay * SecsPerMin; //86400 MSecsPerDay = SecsPerDay * MSecsPerSec; //86400000 .. {dateutil.inc} const OneMillisecond = 1/MSecsPerDay; Function SameDateTime(const A, B: TDateTime): Boolean; begin Result:=Abs(A-B)<OneMilliSecond; end; Function CompareDateTime(const A, B: TDateTime): TValueRelationship; begin If SameDateTime(A,B) then Result:=EqualsValue else If A>B then Result:=GreaterThanValue else Result:=LessThanValue end; Gruß Horst |
AW: CompareDateTime unter XE2 deutlich langsamer als D2009
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 03:23 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