AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Delphi Application.ProcessMessages über Synchronize in Thread erlaubt?
Thema durchsuchen
Ansicht
Themen-Optionen

Application.ProcessMessages über Synchronize in Thread erlaubt?

Ein Thema von berens · begonnen am 28. Jun 2012 · letzter Beitrag vom 29. Jun 2012
Antwort Antwort
Seite 2 von 2     12   
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#11

AW: Application.ProcessMessages über Synchronize in Thread erlaubt?

  Alt 29. Jun 2012, 03:06
Ist der Aufruf von BinFertig tatsächlich so zu verstehen, dass dieser am Ende von Execute aufgerufen wird?

Dann benutze doch einfach das Event OnTerminate, das wird immer dann gefeuert, wenn der Thread fertig ist

btw. CoInitialize und CoUninitialize benutzt du aber schon?
Benutzt du im Thread die gleiche ADOConnection wie im Hauptthread?
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
berens

Registriert seit: 3. Sep 2004
434 Beiträge
 
Delphi 10.4 Sydney
 
#12

AW: Application.ProcessMessages über Synchronize in Thread erlaubt?

  Alt 29. Jun 2012, 09:41
Zitat:
btw. CoInitialize und CoUninitialize benutzt du aber schon?
Aber ich bitte dich, das ist ja wohl selbstverständlich! *Überall schnell einfüg*
^-- Hatte ich bisher nur verwendet, wenn ansonsten ne Fehlermeldung kam. Bei den Ado-Komponenten in einem Thread hab ich bisher noch nicht dran gedacht, sollte bei ActiveX/COM aber natürlich selbstverständlich sein :/

Zitat:
Benutzt du im Thread die gleiche ADOConnection wie im Hauptthread?
Bevor der Thread mit Resume gestartet wird ( bei Create war CreateSuspended = True), setze ich eine StringVariable für den ConnectionString. In Execute werden dann erst die TAdoConnection und das TAdoQuery erzeugt, und AdoConnection.Connectionstring = Variable gesetzt.

OnTerminate ist mir irgendwie nicht so ganz geheuer. Bei einem Thread der in Schleife läuft und nur durch den MainThread mit ".Terminate" beendet werden kann, da befürchte ich dass das Event zu früh kommen könnte (also z.B. wenn ich den Befehl .Terminate aufrufe, und nicht, wenn Execute die letzte Zeile abgearbeitet hat). Und bei FreeOnTerminate existiert das Callback-Objekt vielleicht schon nicht mehr, oder wenn OnTerminate auf eine Prozedur vom eigenen Thread geht, dass dieser schon wegen FreeOnTerminate freigegeben wurde, und die dem FreeOnTerminate-Ereignis zugewiesenen Prozedur kann nicht ausgeführt werden, das das Objekt (der Thread) schon freigegeben wurde. Nennt mich übervorsichtig, aber im Laufe der Jahre habe ich das Vertrauen in solche "Selbstverständlichkeiten" verloren. Wenn jemand mir garantiert, dass das mit FreeOnTerminate nicht der Fall ist, wäre das natürlich eine gute Alternative
  Mit Zitat antworten Zitat
Benutzerbild von BUG
BUG

Registriert seit: 4. Dez 2003
Ort: Cottbus
2.094 Beiträge
 
#13

AW: Application.ProcessMessages über Synchronize in Thread erlaubt?

  Alt 29. Jun 2012, 09:50
Sollte das nicht funktionieren, wäre das ein Bug, über den wahrscheinlich schon einige gestolpert wären:
Zitat von http://docwiki.embarcadero.com/Libraries/en/System.Classes.TThread.OnTerminate:
Occurs after the thread's Execute method has returned and before the thread is destroyed.
Intellekt ist das Verstehen von Wissen. Verstehen ist der wahre Pfad zu Einsicht. Einsicht ist der Schlüssel zu allem.
  Mit Zitat antworten Zitat
WladiD

Registriert seit: 27. Jan 2006
Ort: Celle
141 Beiträge
 
Delphi 11 Alexandria
 
#14

AW: Application.ProcessMessages über Synchronize in Thread erlaubt?

  Alt 29. Jun 2012, 11:36
Man sollte NIEMALS Application.Processmessages manuell aufrufen!
Kannst du das auch begründen? Was ist dagegen einzuwenden die Nachrichtenschlange abzuarbeiten, wenn einem danach ist?
Weil an der Stelle alle anstehenden Messages abgearbeitet werden. Das Schlimmste sind dann die WM_TIMER-Messages (TTimer und Konsorten) die mal dort, mal hier anschlagen und natürlich die Thread-Synchronisierung an sich. Das kann soviele Nebeneffekte (vor allem in einem gewachsenen Projekt) haben, das kann man sich gar nicht vorstellen. So einen Code zu debuggen ist die Hölle (spreche aus Erfahrung) > man kann schlicht vieles nicht reproduzieren. Da kann dann das Programm schonmal abhängig von der CPU-Taktfrequenz/Netzwerk etc. sich unterschiedlich verhalten.

Ich hab's schonmal gesagt: TApplication.Processmessages ist in seiner Form ein Designfehler > es hätte protected sein müssen, dann wären viele Delphi-Anwendung um einiges stabiler.

PS: Es gibt kein einiziges Problem, welches man ohne TApplication.Processmessages nicht lösen könnte, aber man bekommt welche, wenn man's nutzt.
Waldemar Derr
Profil bei GitHub
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Application.ProcessMessages über Synchronize in Thread erlaubt?

  Alt 29. Jun 2012, 13:57
Und deshalb hab ich mir ein ProcessDrawMessages gebastelt, welche keine Timer, Synchronize oder Maus-/Tastenereignisse verarbeitet.

In unserem Programm ist ProcessMessages weit verbreitet und so konnten wenigsten einige Nebenefekte beseitigt werden, ohne gleich alles umbauen zu müssen und das ProcessMessages komplett zu entfernen.

Man nehme nur mal eine Timer, der alle 10 Sekunden zuschlägt, beim Debuggen landet man dann ständig dort drin.
$2B or not $2B
  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 21:01 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 by Thomas Breitkreuz