AGB  ·  Datenschutz  ·  Impressum  







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

Darstellungsproblem bei Programmausführung

Ein Thema von Piro · begonnen am 23. Okt 2005 · letzter Beitrag vom 24. Okt 2005
 
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.259 Beiträge
 
Delphi 2006 Professional
 
#6

Re: Darstellungsproblem bei Programmausführung

  Alt 24. Okt 2005, 08:12
Zitat von daywalker299:
... könnte ihr mir kurz den Sinn erklären zum Thema:
Application.ProcessMessages ...
Hai Sven,

währen deine Schleife durchlaufen wird kommt dein Programm nicht dazu die Nachrichten "die es von Windows bekommt" zu verarbeiten.
Es kann also nicht auf ein verschieben des Fensters, Buttonsklicks oder sonst etwas reagieren. Selbst das neuzeichnen von Labels findet nicht stat.

Durch den Aufruf von Delphi-Referenz durchsuchenApplication.ProcessMessages zwingst Du dein Programm die Nachrichten abzuarbeiten und dann mit der Schleife weiter zu machen.
Hier mal drei Beispiele:
Delphi-Quellcode:
var
  start: cardinal;
  ende: cardinal;

// Ohne Application.ProcessMessages
// Bei mir ca 2000 ms
procedure TDemoForm.btn_Test1Click(Sender: TObject);
var
  ndx: integer;
begin
  start := GetTickCount;
  for ndx := 0 to 100000 do
  begin
    lbl_Counter.Caption := IntToStr(ndx);
  end;
  ende := GetTickCount;
  ShowMessageFmt('Zeit %d', [ende - start]);
end;

// Mit Application.ProcessMessages
// Bei mir ca. 12000 ms
procedure TDemoForm.btn_Test2Click(Sender: TObject);
var
  ndx: integer;
begin
  start := GetTickCount;
  for ndx := 0 to 100000 do
  begin
    lbl_Counter.Caption := IntToStr(ndx);
    Application.ProcessMessages;
  end;
  ende := GetTickCount;
  ShowMessageFmt('Zeit %d', [ende - start]);
end;

// Mit Application.ProcessMessages beil allen maxloop Durchläufen.
// Bei mir ca. 3500 ms
procedure TDemoForm.btn_Test3Click(Sender: TObject);
const
  maxloop = 10;
var
  ndx: integer;
  lcount: integer;
begin
  start := GetTickCount;
  lcount := maxloop;
  for ndx := 0 to 100000 do
  begin
    lbl_Counter.Caption := IntToStr(ndx);
    Dec(lcount);
    if (lcount = 0) then
    begin
      Application.ProcessMessages;
      lcount := maxloop;
    end;
  end;
  ende := GetTickCount;
  ShowMessageFmt('Zeit %d', [ende - start]);
end;
Wie man an den Zeiten sieht ist es aber nicht unbedingt klug ProcessMessages bei jedem Durchlauf aufzurufen da natürlich auch die Abarbeitung der Methode einiges an Zeit braucht.

Darum habe ich in Test3 einfach bestimmt das dies nur bei jedem zehnten Durchlauf passieren soll. Welchen Wert Du hier nimmst ist von deinem Anwendungsfall abhängig.

Ich hoffe es zeigt in etwas worum es geht.
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
 


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 14:59 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