AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

CPU Auslastung 100%

Ein Thema von -187- · begonnen am 23. Mai 2011 · letzter Beitrag vom 27. Mai 2011
Antwort Antwort
Seite 2 von 2     12   
Benutzerbild von Coffeecoder
Coffeecoder

Registriert seit: 27. Apr 2011
242 Beiträge
 
Delphi 6 Enterprise
 
#11

AW: CPU Auslastung 100%

  Alt 27. Mai 2011, 18:55
Auf meiner Suche nach möglichen externen Fehler Analyse Tools bin ich auf den ASMProfiler gestoßen. Finde das Tool klasse und erwähnenswert -> Ich werde es in Zukunft weiterhin einsetzen
Danke für dein Hinweis! Das könnte ich selbst noch gut gebrauchen
Coffeecoder
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.071 Beiträge
 
Delphi 12 Athens
 
#12

AW: CPU Auslastung 100%

  Alt 27. Mai 2011, 23:02
Zitat:
TempStr:=Copy(TempStr,Pos2,Length(TempStr));
Delete(TempStr, 1, Pos2-1); löscht direkt im String und wenn man FastMM verwendet (ist seit einer Weile im Delphi integriert), dann kommt es nun manchmal vor, daß der String nicht umkopiert wird, da FastMM es, unter verschiedenen Voraussetzungen, schafft Speicher inplace zu verkleinern/vergrößern.

Gegenüber dem Kopier, wo immer umkopiert wird, spart man nun also manchmal etwas.

PS: Noch schneller geht es, wenn man die Logik selber optimiert.

- Wozu wird myResultStr in jedem Schleifendurchlauf erstellt?
Einmal am Ende reicht vollkommen.

- Dann muß man TempStr nicht ständig ändern (was rauslöschen), wenn man in der Schleife nur noch via PosEx sucht und den, jetzt noch gelöschten Teil, einfach überspringt/ignoriert.
Falls man nun TempStr wirklich am Ende einzeln braucht, dann kann man nach der Schleife immernoch das Gewünschte, nur noch einmal, weglöschen.




Und nochmal was zu den Profilern:
Bitte die Ergebnisse nicht für das Non plus ultra halten,
denn Messen beeinflußt das Messergebnis.

Ich hatte mal in einem Code nach der "Bremse" gesucht.
Leider wurde da das Ergebnis einer Schleife (ich würde sie mal hochoptimiert nennen) dermaßen schlimm verändert, daß am Ende diese Schleife als Bremse erkannt wurde.

Leider war es nicht die Schleife, denn ohne Messung war sie sehr schnell und eine andere Stelle war die eigentliche Ursache.
> sehr viele kurze Schleifendurchgänge > viel Beeinflussung
> das andere war langsam, aber wurde nur selten ausgeführt > wenig Beeinflussung
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu (27. Mai 2011 um 23:12 Uhr)
  Mit Zitat antworten Zitat
-187-

Registriert seit: 24. Sep 2005
483 Beiträge
 
Delphi 2010 Architect
 
#13

AW: CPU Auslastung 100%

  Alt 27. Mai 2011, 23:58
Interessanter Beitrag Ok, du hast Recht, meine Schleife ist noch nicht ganz ausgereift

Aha! Gut zu wissen. Naja ich kannte die Profiler bisher garnicht und werde erstmal ein bisschen damit rumspielen.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 13:40 Uhr.
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