![]() |
AW: Schleife beschleunigen sinnvoll?
Polling sollte – meiner Meinung nach – möglichst nur auf unterster Ebene geschehen, also etwa durch einen Treiber. Ausnahmen wären natürlich sowas wie „Server anpingen, um zu prüfen, ob er up ist“. Da tun es dann aber in der Regel auch große Intervalle von 1s und mehr. Das finde ich dann auch wieder in Ordnung, aber sleep(1) ist für mich ein starker Indikator für einen Designfehler. Ist gewissermaßen Symptonbekämpfung statt die Ursache zu beheben...
|
AW: Schleife beschleunigen sinnvoll?
Hmmm. Verstehe das Problem nicht so ganz.
Entweder habe ich verdammt viel zu rechnen und das soll schnell gehen und dann ist eine CPU zu 100% gerade gut genug. Oder ich kann mir Zeit lassen und will daher eine CPU nicht zu 100% auslasten. Dann rechne ich in Häppchen und lasse andere (Prozesse) auch zum Zuge kommen. Dann muss ich das dem OS aber (leider) sagen. Im Allgemeinen spielen viele Threads/Prozesse zusammen und müssen sich synchronisieren, ergo wird man dieses Problem in der Form nicht so oft haben. Und wenn doch, lässt es sich doch imho auf die eingangs genannten zwei Fälle reduzieren. @Namenlozer: Stichwort 'Eventuell Designfehler?' - ACK, mit der Betonung auf 'eventuell'. |
AW: Schleife beschleunigen sinnvoll?
Zitat:
Schnittstellen zu anderen Programmen laufen auch teilweise nur so, dass man wartet bis eine bestimmte Datei beschreibbar ist oder vorhanden ist oder oder... Ob das gutes Design ist, sei mal dahingestellt, aber angebotene Schnittstellen kann man nun einmal nicht immer beeinflussen. Und ohne eine direkte Kommunikation der Programme gibt es auch nicht so viele Möglichkeiten. Eine Druckjobüberwachung funktioniert z.B. meines Wissens auch nur mit Pollen, zumindest habe ich noch keine Möglichkeit gefunden mich benachrichtigen zu lassen, wenn einer fertig ist. Und da gibt es noch viel mehr Gelegenheiten, bei denen du keine andere Möglichkeit hast als zu pollen. |
AW: Schleife beschleunigen sinnvoll?
Zitat:
Aber selbst auf der niedrigsten Stufe bringt das nichts wenn die Schleife ohne unterbrechung läuft. Man muss halt nur die richtige position finden an der man den Thread schlafen legt wenn auch nur eine millisekunde.
Code:
geht!
VisualizationRunning = true;
ThreadStart renderTs = new ThreadStart(this.RunRenderThread); VizRenderThread = new Thread(renderTs); VizRenderThread.Priority = ThreadPriority.AboveNormal; //< Hat keinen einfluss auf die auslastung der CPU VizRenderThread.IsBackground = true; VizRenderThread.Name = "VizRenderer"; VizRenderThread.Start();
Code:
geht nicht!
if (VisualizationRunning)
{ using (Graphics g = Graphics.FromHwnd(Handle)) { // Fixed High CPU mistake Thread.Sleep(1);
Code:
if (VisualizationRunning) { // Fixed High CPU mistake Thread.Sleep(1); using (Graphics g = Graphics.FromHwnd(Handle)) { gruss |
AW: Schleife beschleunigen sinnvoll?
Die Threadpriorität hat natürlich keine Auswirkungen auf deinen Anwendungsfall, denn Du gibst (ohne das sleep) dem OS überhaupt keine Gelegenheit, andere zum Zuge kommen zu lassen. Threads sind kooperativ, d.h. sie müssen 'Bescheid' geben, wann und wo sie unterbrochen werden können. Offensichtlich trifft das auch auf den Prozess zu, obwohl ich dachte, das Windows hier präemptives Multitasking umsetzt.
Aber offensichtlich ist es so: Du und deine Freunde teilen sich eine Pizza. Du hast großen Hunger, also gibst Du dir eine hohe Priorität. Das funktioniert dann, wenn jeder sich reihum einen Haps nimmt (alle einen gleich großen), nur Du darfst jeweils einen großen Bissen nehmen. Logisch: Wenn sich alle eine hohe Priorität geben, ist der Effekt auch = 0. Und bahnbrechend ist der Effekt eh nicht, nur du bekommst eben ein wenig mehr (weil deine Freunde mitspielen und wenig abbeißen). Wenn Du allerdings die Pizza nicht mehr aus der Hand gibst, ist es irrelevant, ob Du eine hohe oder sehr niedrige Priorität hast, weil ja dann das verabredete Prozedere (jeder reihum abbeißen) nicht eingehalten wird. Du ißt sie also ganz alleine auf. Entweder mit kleinen Bissen (niedrige Priorität) oder mit Riesenhapsen (hohe Priorität). Da wir nicht wissen, was Großartiges mit dem 'Graphics g' anstellst, kann man da auch nicht weiter ansetzen. Ach: Wieso ist das eigentlich ein 'high CPU mistake'? Wenn schon ein 'mistake', dann eher von Dir bzw. dem Design. Der Thread rennt endlos ohne Pause und rendert irgend etwas? Was rendert er? Wann ändert sich etwas bei der Darstellung? Reicht es nicht, das Rendern nur dann anzuwerfen, wenn es etwas *Neues* zu rendern gibt, d.h. wenn sich der Output ändern wird? Reicht es nicht, nur z.B. 20x pro Sekunde zu Rendern? |
AW: Schleife beschleunigen sinnvoll?
Zitat:
Er schickt also die aktuelle position im Stream das StreamHandle die gebufferten Wasapi Samples etwaige änderungen der Bildgröße usw... Alle 20x pro Sek. reicht da bei weitem nicht aus schließlich will ich nicht mit 10Frames in der sekunde rendern. Das sollte schon in realzeit geschehen. Denn ein Beaterkennung die 5 Sekunden später auftritt als sie eigentlich sollte ist sinnlos. Ist also nicht nur eine frage des Gehörs sondern auch der Augen. Ist wie mit deiner Pizza! Man isst nicht nur sondern schmeckt auch noch. Zitat:
Ah jo mein englisch ist halt unter der Gürtellinie hätte auch schreiben können 'high CPU Usage' wenn es dir mehr zusagt. Zitat:
Man hätte hier nicht sleepMS definieren sollen sondern damit den Thread warten lassen.. Warum nicht anstelle von
Code:
int sleepMS = RenderVisualization(g);
Code:
Somit hätte man auch den crash entgegenwirken können wenn beim beenden der Anwendung
Thread.Sleep(RenderVisualization(g));
die Form nicht mehr existiert und dann versucht 'g' zu initialisieren. aber das darf jetzt nicht mehr mein problem sein. gruss |
AW: Schleife beschleunigen sinnvoll?
Zitat:
Solange man aber nicht kurz wartet und einfach nur alles nimmt was man bekommen kann, wird die CPU auch ausgelastet solange niemand anderes sie braucht. |
AW: Schleife beschleunigen sinnvoll?
Gibt es nicht doch noch ne bessere alternative als Tread.Sleep(1)
Man mag es nicht glauben aber selbst die 1 Millisekunde blockiert schon das rendern. Also für C#.. wenn da jemand was hat wüde mich das freun ;) gruss |
AW: Schleife beschleunigen sinnvoll?
Zitat:
|
AW: Schleife beschleunigen sinnvoll?
Zitat:
Ich glaube das ich für das problem einen Multimediatimer benötige da dieser auch im nano bereich arbeitet. Die 1 Millisekunde ist einfach noch zu viel. Beim Thread ohne Pause ist es zu schnell so das andere prozesse dadurch behindert werden. Aber diese geschwindigkeit wäre korrekt wenn das blockieren nicht wäre. Das ist mein problem ;) gruss |
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:36 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