Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Neuen Beitrag zur Code-Library hinzufügen (https://www.delphipraxis.net/33-neuen-beitrag-zur-code-library-hinzufuegen/)
-   -   Delphi Delay (https://www.delphipraxis.net/169718-delay.html)

negaH 13. Sep 2012 22:47

AW: Delay
 
Zitat:

Zitat von hathor (Beitrag 1177406)
Ehrlich gesagt: Ich halte dieses Delay für grossen Mist!

http://support.microsoft.com/kb/172338/de
Zitat:
...
Wenn Ihr System Zähler mit hoher Genauigkeit unterstützt, können Sie "QueryPerformanceCounter" und "QueryPerformanceFrequency" verwenden, um äußerst genaue Zeitmessungen durchzuführen.

Jo, man macht im Mikrosekunden bis Nanosekundenbereich per QueryPeformanceCounter Messungen die durch den Betriebsystem-Tasksheduller nur mit 20 Millisekunden Genauigkeit aufgerufen werden. Das nenn ich dann idiotischen Schwachsinn.

Man hat also eine Atomuhr bei der der Beobachter nur alle +-20 Millisekunden die Zeit ablesen tut.


Gruß Hagen

Furtbichler 14. Sep 2012 06:30

AW: Delay
 
Das kommt auf die Implementierung an. Mit QPC kann ich wieder nanosekundenlang warten. Ok, blockierend, aber dafür extremstens(!) genauestens(!!1!EINS)

Ich lass mir doch mein Delay des 21.Jahrhunderts nicht durch Abarbeiten der MSQ ad absurdum führen.

himitsu 14. Sep 2012 09:39

AW: Delay
 
Programme laufen nicht durchgehend.
Sie werden über den Task Scheduler immer mal wieder angehalten, bzw. sie bekommen nur abechselnd ein paar Millisekunden lang Rechenzeit.
Wenn Windows das Programm kurz vor dem Messen schlafen legt, dann kann man die berechnete Pause so klein machen, wie man will ... die Messung geschieht erst bei der nächsten Bearbeitung und das kann unterschiedlich lang mehrere Millisekunden dauern, je nach Systemauslastung und Priorisierung.

Auch braucht das Verarbeiten der Messages (egal ob NonVCL oder über ProcessMessages) auch seine Zeit, sodaß man die Schleife sowieso nicht immer ganz geneu abbrechen kann.

negaH 16. Sep 2012 19:20

AW: Delay
 
Zitat:

Zitat von Furtbichler (Beitrag 1182854)
Das kommt auf die Implementierung an. Mit QPC kann ich wieder nanosekundenlang warten. Ok, blockierend, aber dafür extremstens(!) genauestens(!!1!EINS)

Ich lass mir doch mein Delay des 21.Jahrhunderts nicht durch Abarbeiten der MSQ ad absurdum führen.

Doch das tust du denn du hast im Normalfalle garkeinen Einfluß darauf. Nur wenn du einen Kernelmode Treiber programmieren könntest kämst du zumindest auf Betreibsystemebene nahe an das dran was du dir da erträumst. Aber dann hast du noch die Hardwareebene bestehend aus Non Maskablen Interrupts und den vielen anderen IRQs usw. die ebenfalls Prozessoraufmerksamkeit auf sich ziehen. Auch diese müsstest du unterbinden können, was theoretisch auch geht. Hast du das geschafft dann fehlt noch alles was CPU Latenzen/Waitstates erzeugen könnte wie Caches, DMA Transfers usw. Und das geht letzendlich nur durch direkte Eingriffe in die HW-Architektur. Mit anderen Worten: das Windows kein predictables OS ist liegt in der HW begründet. Du wirst es nicht schaffen mit einfachen CPU Zählern ein echtes und genaues Zeitmanagement in Nanosekunden Auflösung hinzubekommen. Sowohl nicht in der Reaktionszeit deines Codes auf diese Zähler noch bei der zeitexakten und unterbrechungsfreien Ausführung deines Codes.

Gruß Hagen

Furtbichler 17. Sep 2012 06:55

AW: Delay
 
Ich bin da nicht der richtige Ansprechpartner. Mir ist das alles schon klar.
Ich hätte wohl mehr :mrgreen: und :stupid: und :wink: in meinen Beitrag streuen sollen.


Alle Zeitangaben in WEZ +1. Es ist jetzt 22:33 Uhr.
Seite 2 von 2     12   

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