Delphi-PRAXiS
Seite 3 von 5     123 45      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Schleifenabbruch durch Esc Taste... (https://www.delphipraxis.net/182573-schleifenabbruch-durch-esc-taste.html)

p80286 7. Nov 2014 12:28

AW: Schleifenabbruch durch Esc Taste...
 
Und wie wäre es mit einem
Delphi-Quellcode:
application.processmessages
?

Gruß
K-H

Dejan Vu 7. Nov 2014 12:30

AW: Schleifenabbruch durch Esc Taste...
 
Ich meinte nur:
Sleep(0) - Threadwechsel
Sleep(1...9999) - Warten und Threadwechsel

Dann habe ich deine Intention von 'Sleep(1)' verstanden...

Dalai 7. Nov 2014 13:41

AW: Schleifenabbruch durch Esc Taste...
 
Zitat:

Zitat von p80286 (Beitrag 1279046)
Und wie wäre es mit einem
Delphi-Quellcode:
application.processmessages
?

Das steht ja bereits drin, hilft aber laut Aussage des OP nichts. Unabhängig davon entgegnet das nicht der Auslastung, aber es sollte die Verzögerung beheben, was es bei mir auch tut.

MfG Dalai

BUG 7. Nov 2014 14:08

AW: Schleifenabbruch durch Esc Taste...
 
Zitat:

Zitat von Dejan Vu (Beitrag 1279042)
Soweit ich mich erinnere, muss der Thread schon selber Bescheid geben, wenn er unterbrochen werden könnte, meist durch API-Aufrufe.

Definitiv nicht. Sleep gibt den Prozessor freiwillig ab, blockierende Systemaufrufe auch. Ansonsten sind Threads präemptiv, dh. dem Thread wird die CPU entrissen wann immer das Betriebsystem Lust dazu hat.

Zitat:

Zitat von himitsu (Beitrag 1279041)
Dann kann der Thread den Prozess lahmlegen. [...] Soweit ich weiß, unterbricht Windows die Threads nicht selbst, sondern nur die Prozesse...

Man unterscheidet User-Level-Threads und System-Level-Threads. Von User-Level-Threads hat das System keine Ahnung und sie laufen nicht parallel. Unter Windows könnten das Fibers (sind eher Coroutinen) sein, man könnte es auch selbst implementieren. System-Level-Threads sind dem System bekannt und können echt parallel laufen. Die normalen Threads, die man in der Regel benutzt, sind System-Level-Threads.

Zitat:

Zitat von Dalai (Beitrag 1279045)
Ich vermute, dass der GUI-Thread derselbe ist wie der der Schleife - und da der mit der Schleife zu tun hat, kommt er nicht mehr zum Bearbeiten der GUI.

Ich auch ... schon weil das in einem Ereignishandler läuft, der vermutlich vom Mainthread aufgerufen wird. Dann sollte ProzessMessages aber ausreichen, da es der GUI nicht helfen sollte, wenn der Thread die Kontrolle abgibt.


Deswegen: Irgendwas läuft da verkehrt :gruebel:

Blup 7. Nov 2014 17:02

AW: Schleifenabbruch durch Esc Taste...
 
Delphi-Quellcode:
{...}
Caption := inttostr(i);
{...}
Schon mal überlegt, was alles passiert, wenn die Caption eines Formulars geändert wird?
Da wird nicht nur ein Feld in der VCL-Klasse verändert.

Codix32 7. Nov 2014 17:21

AW: Schleifenabbruch durch Esc Taste...
 
Liste der Anhänge anzeigen (Anzahl: 1)
Zitat:

Zitat von himitsu (Beitrag 1279041)

...
Was ist das denn für ein PC?
Wieviele Kerne gibt es und wie sind die ausgelastet? (während der Schleife und in den 12 Sekunden, bzw. davor/danach)
Wie sieht der RAM aus? (im Cache, Verfügbar, Frei, Ausgelagert und Zugesichert)

Bei einer 1-Kern-CPU kann man mit einem Thread ja problemlos alles lahmlegen. -> genausoviel/mehr Aufgaben (ala arbeitende Threads), als Arbeiter (Kerne)

  • Acer Predator G3610
    8 GB RAM
    64 Bit - Betriebssystem
    Prozessorkerne 4
    Grafik AMD Radeon HD 6870

Du wirst es vielleicht nicht glauben, aber wenn ich den Task Manager aufrufe und die Leistung anzeige, bleibt selbst die Grafik stehen, die sonst im Sekunden Rhythmus von rechts nach links läuft. Im Ressourcen Monitor werden gleich 8 Kerne angezeigt, obwohl die CPU bloß 4 Kerne hat ?!?
Im Ressourcenmonitor bleibt die Grafik nicht hängen und die Kerne 0, 2 und 4 schlagen aus.

Ups. Im 2. Versuch bleibr auch der Resourcenmonitor kurz stehen, zeigt dann aber Ausschläge bis fast 100% bei Kernen 2, 4 und 6 an.

BUG 7. Nov 2014 17:44

AW: Schleifenabbruch durch Esc Taste...
 
Zitat:

Zitat von Blup (Beitrag 1279092)
Schon mal überlegt, was alles passiert, wenn die Caption eines Formulars geändert wird?

Stimmt, vermutlich wird da jedes mal eine Nachricht gesendet :shock:
Das könnte schon ein bisschen Ärger machen.

Zitat:

Zitat von Codix32 (Beitrag 1279096)
Im Ressourcen Monitor werden gleich 8 Kerne angezeigt, obwohl die CPU bloß 4 Kerne hat ?!?

Wahrscheinlich Hyperthreading: Jeder echte Kern stellt 2 Hardware-Threads bereit. Die werden nicht echt gleichzeitig ausgeführt, können aber Wartezeiten im Prozessor überbrücken.

Codix32 7. Nov 2014 17:59

AW: Schleifenabbruch durch Esc Taste...
 
Zitat:

Zitat von BUG (Beitrag 1279100)
Zitat:

Zitat von Blup (Beitrag 1279092)
Schon mal überlegt, was alles passiert, wenn die Caption eines Formulars geändert wird?

Stimmt, vermutlich wird da jedes mal eine Nachricht gesendet :shock:
Das könnte schon ein bisschen Ärger machen.

Zitat:

Zitat von Codix32 (Beitrag 1279096)
Im Ressourcen Monitor werden gleich 8 Kerne angezeigt, obwohl die CPU bloß 4 Kerne hat ?!?

Wahrscheinlich Hyperthreading: Jeder echte Kern stellt 2 Hardware-Threads bereit. Die werden nicht echt gleichzeitig ausgeführt, können aber Wartezeiten im Prozessor überbrücken.

Wie kann ich das prüfen, ob es das Form1.caption ist?
Wenn ich das Caption auskommentiere läuft die Schleife zu schnell ab. Vielleicht eine zweite Schleife rein? Mal sehen.

BUG 7. Nov 2014 18:32

AW: Schleifenabbruch durch Esc Taste...
 
Zitat:

Zitat von Codix32 (Beitrag 1279104)
Vielleicht eine zweite Schleife rein? Mal sehen.

Entweder das, oder:
Zitat:

Zitat von Dalai (Beitrag 1278439)
Warum überhaupt eine for-Schleife mit einem hohen Zahlenwert als Abbruchbedingung statt einer while- oder repeat-until-Schleife?


himitsu 7. Nov 2014 18:45

AW: Schleifenabbruch durch Esc Taste...
 
Zitat:

Zitat von BUG (Beitrag 1279100)
Stimmt, vermutlich wird da jedes mal eine Nachricht gesendet :shock:
Das könnte schon ein bisschen Ärger machen.

Und keiner gibt dem MainThread Zeit diese zu verarbeiten.

Das passiert alles erst nach dem Ende der Methode, bzw. beim Anzeigen des Abbruch-Dialogs.


Alle Zeitangaben in WEZ +1. Es ist jetzt 06:57 Uhr.
Seite 3 von 5     123 45      

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