AGB  ·  Datenschutz  ·  Impressum  







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

Formulare und Threads

Ein Thema von MStoll · begonnen am 5. Jan 2006 · letzter Beitrag vom 5. Jan 2006
Antwort Antwort
MStoll

Registriert seit: 15. Nov 2005
131 Beiträge
 
Turbo Delphi für Win32
 
#1

Formulare und Threads

  Alt 5. Jan 2006, 13:54
Hi @all,

ich habe ein Problem mit Formularen und anderen Threads als dem Hauptthread. Ist es so, dass man Formulare nicht aus anderen Threads heraus erzeugen bzw. anzeigen kann?
Ich habe eine Multi-Monitor-Anwendung geschrieben, in der man für jeden verfügbaren Bildschirm bestimmen kann, ob auf diesem etwas angezeigt wird und was angezeigt wird. Dazu baue verwende ich ein dynamisches Array aus Formularen.

Hier mal etwas Code:

Delphi-Quellcode:
var TVForms : array of TForm;

//...

procedure FreeForms;
var x : integer;
begin
     for x := 0 to High(TVForms) do
         TVForms[x].Free;

     SetLength(TVForms, 0);
end;

procedure TFormThread.Execute;
var x : integer;
begin
     while not(terminated) do
     begin
          //Falls bereits vorhanden, evtl. "alte" Formulare zerstören (ab dem 2. Schleifendurchlauf)
          FreeForms;
          SetLength(TVForms, {les ich aus ner Konfiguration aus, kann jederzeit geändert werden});
          for x := 0 to High(TVForms) do
          begin
               // Hier geht's nicht weiter!
               TVForms[x] := TForm.create(nil);

               //... Mache irgendwas damit
          end;
          Sleep(15000);
     end;
end;
Dass ich die Formulare jedesmal neu aufbaue, hängt damit zusammen, dass das Programm im Hintergrund laufen soll, bedient wird es über Konfigurationsdateien und Netzwerkbefehle. D.h. die Anzahl der Formulare kann zur Laufzeit geändert werden.
Ich hoffe, ihr versteht, was ich meine. Danke schonmal.

Gruß
Michael
  Mit Zitat antworten Zitat
Benutzerbild von chaosben
chaosben

Registriert seit: 27. Apr 2005
Ort: Görlitz
1.358 Beiträge
 
Delphi XE2 Professional
 
#2

Re: Formulare und Threads

  Alt 5. Jan 2006, 14:46
Herzlich willkommen in der DelphiPraxis!

Erstmal etwas grundsätzliches zu Threads und Forms: Jeder Thread darf sich ohne Synchronisierung nur um seine eigenen Forms kümmern.
Dazu ein Zitat aus meinem Post im Delphi-Forum:
Zitat:
Dein Thread läuft ja nun durch die CPU wie er will. Er ist dabei völlig unabhängig vom Hauptthread, der sich z.B. um das Formular und speziell in diesem Fall um das Label kümmert. Wenn deinem Thread jetzt einfällt, das er etwas mit den Resourcen des anderen Threads machen möchte, dann sollte das "synchron" passieren, also so, das es zu keinen Konflikten zwischen den beiden Threads kommt. Das betrifft vor allen Dingen Aktionen mit grafischen Elementen. Der Synchronize-Prozedur übergibst du als einzigen Parameter eine Member-Prozedur des Threads (In diesem Fall "UpdateVCL"). Damit wartet der TTimeSync-Thread darauf, bis der Hauptthread wieder in seine Message-schleife kommt und macht dann erst seine Änderunge. Als Gegen-Beispielt kannst du einfach in deinem Thread mal ne MessageBox aufmachen. Du wirst dich wunderen wieviele verschiedene Formen eine Messagebox haben kann.
Lange Rede kurzer Sinn: Du musst deinen Thread wahrscheinlich mit dem Hauptthread synchronizen.
Benjamin Schwarze
If I have seen further it is by standing on the shoulders of Giants. (Isaac Newton)
  Mit Zitat antworten Zitat
MStoll

Registriert seit: 15. Nov 2005
131 Beiträge
 
Turbo Delphi für Win32
 
#3

Re: Formulare und Threads

  Alt 5. Jan 2006, 15:09
Erstmal danke für deine Antwort.

Nun zu der Sache mit dem Synchronisieren:
Ich greife mit dem Hauptthread gar nicht auf die Formulare zu. Ich wollte sie mit dem Hintergrund erstellen, modifizieren, anzeigen und auch wieder freigeben. Das ganze sollte automatisch geschehen. Der Benutzer sieht das Hauptformular mit dem VCL-Thread meistens gar nicht --> Also keine Klicks etc.
Der Hintergrundthread soll ganz unabhängig arbeiten (Konfiguration einlesen, alte Formulare freigeben, erforderliche Formulare ermitteln, Daten lesen, verarbeiten, Formulare erstellen, Daten anzeigen). D.h. da muss eigentlich nichts synchronisiert werden.

Ich hab da so 'ne Vermutung, ich weiß halt nicht, ob sie stimmt:
Und zwar könnte es sein, dass Delphi beim Erstellen bzw. Anzeigen eines Formulars das Formular beim VCL-Thread "anmeldet", damit über diesen auf Formular-Ereignisse zugegriffen werden kann. Wäre es vielleicht möglich, dass man dies verhindert, da ich ja die Formulare nur zum Anzeigen von Daten benutzen will? Vielleicht hat ja einer von euch noch ne Idee.

Wie gesagt, diese Formulare dienen rein der Ausgabe. Sie sollten also irgendwie nicht auf Benutzerereignisse warten, falls das irgendwie zu machen ist.

Bitte um weitere Vorschläge. Vielen Dank.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

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

Re: Formulare und Threads

  Alt 5. Jan 2006, 15:16
Zitat von MStoll:
Ich greife mit dem Hauptthread gar nicht auf die Formulare zu. Ich wollte sie mit dem Hintergrund erstellen, modifizieren, anzeigen und auch wieder freigeben. Das ganze sollte automatisch geschehen. Der Benutzer sieht das Hauptformular mit dem VCL-Thread meistens gar nicht --> Also keine Klicks etc.
Der Hintergrundthread soll ganz unabhängig arbeiten (Konfiguration einlesen, alte Formulare freigeben, erforderliche Formulare ermitteln, Daten lesen, verarbeiten, Formulare erstellen, Daten anzeigen). D.h. da muss eigentlich nichts synchronisiert werden.
Jedes Formular hat so einen eigenen Thread laufen, und jeder Thread der da so durch die Gegend läuft hat damit erst mal nix zu tun.
Das Formular muss sich ja auch mit anderen Dingen rungsherum noch absprechen (Fensterhandler etc.).
Also jede Aktion auf ein Formular muss synchronisiert werden.

Aber mach doch einfach folgendes:

In den Formularen lass einen Timer laufen, der alle x-Millisekunden die Daten auf dem Formular aktualisiert.
Die Daten lässt du vom Thread in einem Objekt bereitstellen.

Also bildhaft gesprochen: Der Daten-Beschaffungs-Thread macht Daten-Beschaffung und speichert dies in einem Objekt und der Anzeige-Thread (also das Formular) kümmert sich auch nur um die Anzeige

cu
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.196 Beiträge
 
Delphi 10.4 Sydney
 
#5

Re: Formulare und Threads

  Alt 5. Jan 2006, 15:18
Soviel ich weiß dürfen VCL-Controls nur im Hauptthread erzeugt werden. Es bringt nicht wenn das Komplette Formular im Thread erzeugt wird da interaktionen mit dem TApplication-Objekt und der MessageQueue im Hauptthread erfolgt.

Eine Möglichkeit wäre (mit entsprechenden COM-Nachteilen) diese Formulare in eine kleine COM-Komponente auszulagern. Da diese auch im Thead erzeugt werden darf und diese Komponente ein eigenes Application-Objekt hat dürft da nichts passieren. Auch die verlagerung in eine DLL mit eigener DLL-Application-Instanz könnte das Problem lösen. Bei DLL darfst Du vermutlich nicht mit Laufzeitpackages arbeiten.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
MStoll

Registriert seit: 15. Nov 2005
131 Beiträge
 
Turbo Delphi für Win32
 
#6

Re: Formulare und Threads

  Alt 5. Jan 2006, 15:22
Danke für die Antworten.

@Sir Rufo: Das hätte ich auch alles gemacht, WENN ich vorher wüsste, wieviele Formulare ich brauche. Das allerdings wird erst vom Daten-Beschaffungs-Thread (*g*) festgelegt, weil der aus den Daten herausliest, wieviele Formulare benötigt werden. Also is prinzipiell nur dieser Thread in der Lage, die Formulare zu erzeugen, da nur er die nötigen Informationen dazu besitzt.

@Bernhard Geyer: Das wäre mal ein Versuch wert. An DLLs hab ich aus anderen Gründen in dem Zusammenhang schon gedacht. COM-Komponente wäre in dem Fall wie mit Kanonen auf Spatzen geschossen.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

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

Re: Formulare und Threads

  Alt 5. Jan 2006, 15:37
Zitat von MStoll:
@Sir Rufo: Das hätte ich auch alles gemacht, WENN ich vorher wüsste, wieviele Formulare ich brauche. Das allerdings wird erst vom Daten-Beschaffungs-Thread (*g*) festgelegt, weil der aus den Daten herausliest, wieviele Formulare benötigt werden. Also is prinzipiell nur dieser Thread in der Lage, die Formulare zu erzeugen, da nur er die nötigen Informationen dazu besitzt.
Nöö, nicht wirklich, wenn Du in Deinen Objekten (die die Daten beherbergen sollen) auch noch einen Pointer auf das entsprechende Formular mitgibst, dann kannst Du dieses mit dem Hauptformular steuern und die Anzeige der Daten auch.
Genauso kann man auch die Löscheng des Forms wieder veranlassen, einfach einen Flag in den Daten, ob ein Form angezeigt werden muss oder nicht. Form-Pointer auf NIL=kein Formular angelegt, Form-Pointer <> NIL=Form is da und wird gefreeeeet wenn nötig.

cu
  Mit Zitat antworten Zitat
MStoll

Registriert seit: 15. Nov 2005
131 Beiträge
 
Turbo Delphi für Win32
 
#8

Re: Formulare und Threads

  Alt 5. Jan 2006, 15:49
Das wäre so ein Gedanke, sofern das mit dem Timer funktioniert (wobei ich mir da nicht sicher bin, denn ein Timer stellt ja auch nur einen neuen Thread dar). Ansonsten bin ich soweit wie vorher, da niemand da is, der neue Formulare dynamisch erzeugen kann (Das Hauptformular macht - wie schon gesagt - gar nix).
  Mit Zitat antworten Zitat
MStoll

Registriert seit: 15. Nov 2005
131 Beiträge
 
Turbo Delphi für Win32
 
#9

Re: Formulare und Threads

  Alt 5. Jan 2006, 15:55
Aber es ist schon gut. Wenn's ne einfache Möglichkeit gegeben hätte, Formulare genauso wie andere Variablen in Hintergrundthreads zu verwenden, dann wär's ok gewesen. Ihr braucht euch jetzt nicht den Kopf zu zerbrechen. Ne etwas umständliche Möglichkeit hab ich bereits in Gebrauch. Dabei wird der Hintergrundthread unterbrochen, wenn über Netzwerk ein Befehl zum Reinitialisieren der Daten kommt, dann werden die Daten im Vordergrund gelesen, die Fenster erzeugt und der Hintergrundthread wird fortgesetzt.
  Mit Zitat antworten Zitat
Antwort Antwort


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 11:12 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