AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Von ThreadA erzeugtes VCL-Objekte von ThreadB freigeben
Thema durchsuchen
Ansicht
Themen-Optionen

Von ThreadA erzeugtes VCL-Objekte von ThreadB freigeben

Ein Thema von s.h.a.r.k · begonnen am 23. Dez 2009 · letzter Beitrag vom 24. Dez 2009
Antwort Antwort
Seite 2 von 2     12   
Benutzerbild von s.h.a.r.k
s.h.a.r.k

Registriert seit: 26. Mai 2004
3.159 Beiträge
 
#11

Re: Von ThreadA erzeugtes VCL-Objekte von ThreadB freigeben

  Alt 23. Dez 2009, 15:43
Ich muss mich euch dann wohl geschlagen geben Aber das kostet mich nun wieder viel Zeit alles zu ändern... Die Welt ist grausam
»Remember, the future maintainer is the person you should be writing code for, not the compiler.« (Nick Hodges)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: Von ThreadA erzeugtes VCL-Objekte von ThreadB freigeben

  Alt 23. Dez 2009, 15:49
Du kannst notfalls mit DLLs arbeiten.

Jedes "getrennte" Fenster in eine DLL.


DLLs haben ja ihre eigene VCL, welches ja grad verhindert, daß man schlecht über EXE/DLL-Grenzen hinweg an gemeinsamen Fenstern arbeiten kann, aber getrennte Fenster lassen sich dafür dann besonders gut verwalten
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
Benutzerbild von s.h.a.r.k
s.h.a.r.k

Registriert seit: 26. Mai 2004
3.159 Beiträge
 
#13

Re: Von ThreadA erzeugtes VCL-Objekte von ThreadB freigeben

  Alt 23. Dez 2009, 15:51
Hm, das ist ein guter Einwand, den ich mir für die Zukunft merken kann. Aber ich liefere gerne nur Exen aus, da ich es hasse, wenn ein Programm mit mehreren hundert Dateien daher kommt und eigentlich nur minimal Aufgaben hat
»Remember, the future maintainer is the person you should be writing code for, not the compiler.« (Nick Hodges)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: Von ThreadA erzeugtes VCL-Objekte von ThreadB freigeben

  Alt 23. Dez 2009, 15:57
Zitat von s.h.a.r.k:
Aber ich liefere gerne nur Exen aus, da ich es hasse, wenn ein Programm mit mehreren hundert Dateien daher kommt und eigentlich nur minimal Aufgaben hat
Mach ich auch gern.

Tjs, dann mußt du eben alle Fenster synchronisiert über den Hauptthread verwalten.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
Benutzerbild von s.h.a.r.k
s.h.a.r.k

Registriert seit: 26. Mai 2004
3.159 Beiträge
 
#15

Re: Von ThreadA erzeugtes VCL-Objekte von ThreadB freigeben

  Alt 24. Dez 2009, 13:31
Da stellt sich mir dann überhaupt die Frage, was ich dann mit Objekten innerhalb eines Thread machen darf?! ich kann ja nie garantieren, dass eine Methode eines beliebigen Objekts nicht doch irgendwas mit einem VCL-Objekt zu tun hat.

Darf ich z.B. Daten aus der Datenbank laden? Pauschal gesagt, doch eigentlich nur synchronisiert, oder? Und dann bringt es mir doch nichts, das Startupprozedere in einen Thread auszulagern, sodass, wie in meinem Beispiel, eine sichtbare Animation flüssig läuft und die Anwendung bedienbar bleibt, da ja das Laden dann ja im MainThread läuft, da synchronisiert wird.

Oder sehe ich daran irgendwas falsch?
»Remember, the future maintainer is the person you should be writing code for, not the compiler.« (Nick Hodges)
  Mit Zitat antworten Zitat
Benutzerbild von wicht
wicht

Registriert seit: 15. Jan 2006
Ort: Das schöne Enger nahe Bielefeld
809 Beiträge
 
Delphi XE Professional
 
#16

Re: Von ThreadA erzeugtes VCL-Objekte von ThreadB freigeben

  Alt 24. Dez 2009, 16:38
Hi!

Zitat:
Da stellt sich mir dann überhaupt die Frage, was ich dann mit Objekten innerhalb eines Thread machen darf?! ich kann ja nie garantieren, dass eine Methode eines beliebigen Objekts nicht doch irgendwas mit einem VCL-Objekt zu tun hat.
Doch, das musst du können. Wenn ich z.B. einen Thread TFileParseThread habe, übergebe ich den Dateinamen und eventuell Parameter an den Thread, der erstellt sich einen TFileStream, benutzt ihn, und gibt ihn wieder frei. Kein VCL-Zugriff. Die Ergebnisse reicht der Thread dann nach längerer Arbeit kurz an den Haupt-Thread durch, welcher dann die Eigenschaften der Grafischen Komponenten setzt, je nach Daten, die der Thread mitgeteilt hat. Irgendwelche (visuellen) Objekte von der Form haben in einem Thread halt nix zu suchen.

Zitat:
Darf ich z.B. Daten aus der Datenbank laden? Pauschal gesagt, doch eigentlich nur synchronisiert, oder?
Du meinst, weil du eine SQLConnection-Komponente (oder wie es heißt) im Form hast und diese an den Thread weiterreichst? Entweder solange wie der Thread läuft dem Form den Zugriff auf die Komponente verbieten oder aber im Thread eine eigene Verbindung aufbauen (nicht Objekt von Form mitgeben, sondern TSQLConnection direkt im Thread erzeugen). Oder dir einen Connection-Pool bereit halten. Oder, oder... Die Beschränkung, nicht auf VCL-Dinge zuzugreifen, gilt glaube ich nur für Komponenten, die was malen, wie Labels halt zum Beispiel. Allerdings sollte man dabei vorsichtig sein, z.B. könnte ein Event von solchen Dingern dann ein anderes VCL-Teil ansprechen. Und es ist irgendwie sehr unschön, Sachen der Form weiterzugeben an einen Thread.

Am Anfang ist das mit den Threads aller etwas mühselig und auch wenn man diese Problem gemeistert hat werden noch einige andere kommen. Wenn es dann aber irgendwann funktioniert, fühl sich das schon gut an
http://streamwriter.org

"I make hits. Not the public. I tell the DJ’s what to play. Understand?"
  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 20:30 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