AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Win32/Win64 API (native code) Delphi COM-Objekte innerhalb von Threads
Thema durchsuchen
Ansicht
Themen-Optionen

COM-Objekte innerhalb von Threads

Ein Thema von CalganX · begonnen am 10. Apr 2007 · letzter Beitrag vom 11. Apr 2007
Antwort Antwort
Seite 1 von 2  1 2      
CalganX

Registriert seit: 21. Jul 2002
Ort: Bonn
5.403 Beiträge
 
Turbo Delphi für Win32
 
#1

COM-Objekte innerhalb von Threads

  Alt 10. Apr 2007, 23:04
Hi,
der ganze OLE/COM-Kram treibt mich gerade zum Wahnsinn.

Ich habe einen Thread, der im Execute Folgendes stehen hat:
Delphi-Quellcode:
  CoInitializeEx(nil, COINIT_MULTITHREADED);
  TunesApp := CoiTunesApp.Create;
  try
    repeat
      {Tue was mit dem TunesApp-Interface}
    until false;
  finally
    TunesApp := nil;
    CoUninitialize;
  end;
Jetzt fliegt mir irgendwann eine EOleSysError-Exception (Erste Gelegenheit für Exception bei $7C812A5B. Exception-Klasse EOleSysError mit Meldung 'Starten des Servers fehlgeschlagen'. Prozess InfoTunes.exe (1708)) an den Kopf, die an folgender Stelle geraiset wird:
Delphi-Quellcode:
class function CoiTunesApp.Create: IiTunes;
begin
  Result := CreateComObject(CLASS_iTunesApp) as IiTunes;
end;
Durch das unmoegliche Debugging von Threads kann ich absolut nicht einschaetzen, warum das alles so passiert und wann genau es zu dieser Exception kommt. Ich vermute, dass der COM-Server ist gar nicht mag, dass in jedem Thread eine neue Referenz erzeugt werden soll.

Weiss jemand, woran das liegen koennte und wie man das Problem loest?

Bin fuer jeden Vorschlag dankbar. Das treibt mich schon den ganzen Tag in den Wahnsinn.
Chris
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.201 Beiträge
 
Delphi 10.4 Sydney
 
#2

Re: COM-Objekte innerhalb von Threads

  Alt 11. Apr 2007, 07:10
Du meinst du tust permanent diese Schleife ablaufen lassen?
Also entweder hat das ITunes-Interface irgendeine Quit/Exit-Methode die man Aufrufen muß bevor man das Interface freigibt oder ITunes hat Speicherlücken die vielen Anforderungen irgendeine Ressourcen (GDI, FileHandels, ...) volllaufen läuft.

Für Fall a, einfach dieses Quit/Exit aufrufen.
Für Fall b, Interface "cachen" und nicht permanent anfordern/freigeben oder auf fehlerbereinigte Version von ITunes warten.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
CalganX

Registriert seit: 21. Jul 2002
Ort: Bonn
5.403 Beiträge
 
Turbo Delphi für Win32
 
#3

Re: COM-Objekte innerhalb von Threads

  Alt 11. Apr 2007, 12:52
Hi Bernhard,
Zitat von Bernhard Geyer:
Für Fall a, einfach dieses Quit/Exit aufrufen.
Ein Quit existiert, hat aber nicht geholfen. Wie es scheint kommt er nichtmal bis dahin. Es gibt schon beim ersten Versuch des CoiTunesApp.Create ein Problem. Genauer gesagt bleibt er erstmal sehr lange in dieser Methode hängen und spuckt nach einiger Zeit den Fehler aus.

Zitat:
Für Fall b, Interface "cachen" und nicht permanent anfordern/freigeben oder auf fehlerbereinigte Version von ITunes warten.
Habe ich jetzt auch versucht: im Dienst-Modul, wo der erste Thread erzeugt wird, wird eine Instanz auf das Interface übergeben. Die wird dann bis zum Ende mitgeschleppt. Aber selbst im Dienst kommt es zum Fehler, d.h. der Dienst startet nicht (da ich so schnell nicht den Debugger anwerfen kann, kann ich nicht sagen, ob es wieder zu einer Exception kommt, aber ich nehme es mal stark an).

Und wie gesagt funktioniert es problemlos, wenn ich keinen Dienst verwende, sondern eine einfache VCL-Anwendung.

Danke für deine Hilfe,
Chris
  Mit Zitat antworten Zitat
Benutzerbild von sakura
sakura

Registriert seit: 10. Jun 2002
Ort: Unterhaching
11.412 Beiträge
 
Delphi 12 Athens
 
#4

Re: COM-Objekte innerhalb von Threads

  Alt 11. Apr 2007, 13:07
Rufe im Thread.Create Delphi-Referenz durchsuchenCoInitialize(nil) auf und im Thread.Destroy Delphi-Referenz durchsuchenCoUnitialize() auf.

Du kannst das natürlich auch an anderer Stelle tun, aber alle COM-Aufrufe und Objekte müssen zwischen Init und Uninit stattfinden.

......
Daniel Lizbeth
Ich bin nicht zurück, ich tue nur so
  Mit Zitat antworten Zitat
CalganX

Registriert seit: 21. Jul 2002
Ort: Bonn
5.403 Beiträge
 
Turbo Delphi für Win32
 
#5

Re: COM-Objekte innerhalb von Threads

  Alt 11. Apr 2007, 13:18
Hi,
habe ich bereits drin. Habe es jetzt korrigiert und in den Service geschrieben:
Delphi-Quellcode:
procedure TInfoTunesService.ServiceCreate(Sender: TObject);
begin
  CoInitialize(nil);

  FTunesInstance := CoiTunesApp.Create;
end;

procedure TInfoTunesService.ServiceDestroy(Sender: TObject);
begin
  CoUninitialize;
end;
Der Service startet immer noch nicht, d.h. er lädt und lädt (in der Systemsteuerung => Dienste) und gibt nach einiger Zeit folgende Fehlermeldung aus:
Zitat:
Der Dienst "..." auf "Lokaler Computer" konnte nicht gestartet werden.

Fehler 1053: Der Dienst antwortete nicht rechtzeitig auf die Start- oder Steuerungsanforderung
Und wie gesagt vermute ich, dass da irgendwo noch eine EOleSysError-Exception geworfen wird, die aber nicht zum Vornschein kommt (da man Dienste ja nur schwer debuggen kann, kann ich hier auch nur vermuten, dass der Fehler immer noch existiert, nur an anderer Stelle).

Chris
  Mit Zitat antworten Zitat
Benutzerbild von sakura
sakura

Registriert seit: 10. Jun 2002
Ort: Unterhaching
11.412 Beiträge
 
Delphi 12 Athens
 
#6

Re: COM-Objekte innerhalb von Threads

  Alt 11. Apr 2007, 13:28
Der Aufruf muss in jeden Thread, evtl. auch in den Service.

Wenn das alles nichts hilft, dan schaue Dir die madExcept Komponenten an - Tutorial in der Tut-Sparte. Für die private Nutzung sind die kostenlos.

......
Daniel Lizbeth
Ich bin nicht zurück, ich tue nur so
  Mit Zitat antworten Zitat
CalganX

Registriert seit: 21. Jul 2002
Ort: Bonn
5.403 Beiträge
 
Turbo Delphi für Win32
 
#7

Re: COM-Objekte innerhalb von Threads

  Alt 11. Apr 2007, 13:30
Hi,
ah, eine Veränderung.
Nachdem ich nun das Erstellen des COM-Objekts in das OnStart verlagert habe und CoInitializeEx mit COINIT_MULTITHREADED verwende, startet der Dienst zumindest:
Delphi-Quellcode:
procedure TInfoTunesService.ServiceCreate(Sender: TObject);
begin
  CoInitializeEx(nil, COINIT_MULTITHREADED);
end;

procedure TInfoTunesService.ServiceDestroy(Sender: TObject);
begin
  CoUninitialize;
end;

procedure TInfoTunesService.ServiceStart(Sender: TService;
  var Started: Boolean);
begin
  FTunesInstance := CoiTunesApp.Create;

  FTCPServer := TTCPDaemon.Create;
  FTCPServer.FTunesInstance := FTunesInstance;
  Started := true;
end;
Jedoch bekomme ich jetzt folgende Nachricht von Windows beim Starten des Dienstes:
Zitat:
---------------------------
Dienste
---------------------------
Dienst "InfoTunes-Service" wurde auf "Lokaler Computer" gestartet und dann angehalten. Einige Dienste werden automatisch angehalten, wenn sie sich im Leerlauf befindet, wie z. B. Leistungsprotokoll- und Alarmdienste.
---------------------------
OK
---------------------------
Im OnExecute steht aber:
Delphi-Quellcode:
procedure TInfoTunesService.ServiceExecute(Sender: TService);
begin
  // Endlosschleife ftw
  while not Terminated do begin
    ServiceThread.ProcessRequests(True);
  end;
end;
Chris

Edit: madExcept ist ein guter Tipp, danke. Dummerweise funktioniert das nicht, weil ich im Moment mit Turbo Delphi entwickle und er das Paket nicht laden kann (ich nehme an, weil man bekanntlich keine Dritt-Anbieter-Komponenten installieren kann).
  Mit Zitat antworten Zitat
CalganX

Registriert seit: 21. Jul 2002
Ort: Bonn
5.403 Beiträge
 
Turbo Delphi für Win32
 
#8

Re: COM-Objekte innerhalb von Threads

  Alt 11. Apr 2007, 13:55
Man sollte gelegentlich auch mal in's Eventlog gucken:
Zitat:
Ereignisinformationen: Service fehlgeschlagen bei start:Starten des Servers fehlgeschlagen, ClassID: {DC0C2640-1415-4644-875C-6F4D769839BA}.
Ich könnte...

Und es funktioniert immer noch problemlos ohne den Dienst, in einer normalen Anwendung. Das kann doch irgendwie nicht sein. :/

Chris
  Mit Zitat antworten Zitat
Benutzerbild von OldGrumpy
OldGrumpy

Registriert seit: 28. Sep 2006
Ort: Sandhausen
941 Beiträge
 
Delphi 2006 Professional
 
#9

Re: COM-Objekte innerhalb von Threads

  Alt 11. Apr 2007, 14:50
Ich hab iTunes bisher auch nur aus einer normalen Applikation heraus benutzt, vielleicht mag iTunes es nicht, wenn der Aufrufer kein Window hat? Was auch noch wichtig ist: iTunes reagiert sehr träge auf Aufrufe, Services dürfen wenn ich mich recht entsinne nur kleine Timeslices in Anspruch nehmen, meine Testapplikation hängt z.B. mehrere Sekunden (singlethreaded, Aufruf im Mainthread, dient nur zum Testen) bevor das CoCreate fertig ist. Sowas könnte bei einem Service fatal sein.
"Tja ja, das Ausrufezeichen... Der virtuelle Spoiler des 21. Jahrhunderts, der Breitreifen für die Datenautobahn, die k3wle Sonnenbrille fürs Usenet. " (Henning Richter)
  Mit Zitat antworten Zitat
CalganX

Registriert seit: 21. Jul 2002
Ort: Bonn
5.403 Beiträge
 
Turbo Delphi für Win32
 
#10

Re: COM-Objekte innerhalb von Threads

  Alt 11. Apr 2007, 17:07
Inzwischen vermute ich das auch. Dann muss ich wohl das ganze ein wenig umbasteln.

Na gut, danke für eure Hilfe und falls jemand doch ne Lösung kennt: immer her damit.

Chris
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 08:19 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