AGB  ·  Datenschutz  ·  Impressum  







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

Schnittstelle ohne COM-Eigenschaft

Ein Thema von Mikkey · begonnen am 26. Aug 2013 · letzter Beitrag vom 27. Aug 2013
Antwort Antwort
Seite 2 von 2     12   
Furtbichler
(Gast)

n/a Beiträge
 
#11

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 27. Aug 2013, 07:46
Warum sollte man denn die Referenzzählung manipulieren wollen? Vergiss 'Free' einfach komplett. Verwende deine Objekte/Interfaces wie gewohnt, aber rufe niemals Free auf. Das brauchst Du nicht!

Wenn Du Objekte in einer Liste hältst und weißt genau, das Du das Element nicht mehr benötigt, dann entferne es aus der Liste.
Wenn Du ein globales Objekt freigeben willst, fang von vorne an (keine globalen Objekte) oder weise der Instanzvariablen einfach nil zu.
  Mit Zitat antworten Zitat
Mikkey

Registriert seit: 5. Aug 2013
265 Beiträge
 
#12

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 27. Aug 2013, 08:09
Ja. Dafür sind die Methoden verantwortlich, die du von IUnknown erbst und in TInterfacedObject für dich implementiert sind.
TInterfacedObject kann ich nicht verwenden, weil ich bei den Klassen, für die es gedacht ist, nicht einfach eine neue Basisklasse unterziehen kann.

Es gibt auch einen Hack über den du die Referenzzählung ausschalten kannst. Dazu musst du AFAIR den Referenzzähler im Konstruktor erhöhen. Somit wird der nie 0 und es verschwindet nix.
Im Code von TInterfacedObject steht nichts weiter als "dec(refCount); if refCount = 0 then Destroy; ". Da würde ich einen solchen Weg nicht wirklich als Hack sehen. Nach einem "CoCreateInstance" wird der Zähler schließlich auch mit 1 initialisiert und eine Klassenreferenz ist im weiteren Sinn auch eine Schnittstellenreferenz.

Du kannst die Referenzzählung aber auch nutzen. Das programmiert sich dann so ähnlich wie die Smartpointer aus C++. Hab ich noch nicht gemacht, aber es gibt manche, die das wirklich mögen. Näheres zu Interfaces liest du z.B. bei Nick Hodges.
Es gibt Dinge, die mache ich nur, wenn etwas Anderes nicht praktikabel erscheint. In C/C++ und Delphi erzeugt man Klassenobjekte selbst. Es gibt keinen wirklichen Grund, sich da einer müllsammlerähnlichen Technik anzuvertrauen. COM hat seine eigenen Regeln, da kommt man nicht drumherum. In C# hat man ebenso keine andere Chance.
  Mit Zitat antworten Zitat
Mikkey

Registriert seit: 5. Aug 2013
265 Beiträge
 
#13

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 27. Aug 2013, 08:24
Warum sollte man denn die Referenzzählung manipulieren wollen? Vergiss 'Free' einfach komplett. Verwende deine Objekte/Interfaces wie gewohnt, aber rufe niemals Free auf. Das brauchst Du nicht!
Es geht nicht um eine Neuprogrammierung. Es handelt sich um Klassen, die bereits existieren und die in einer bestehenden Anwendung angelegt und zerstört werden. Daran werde ich sicher nichts ändern.

Es geht nur darum, dass die bestehenden Objekte nach verschiedenen Aspekten "ähnlich" sind und bzgl. dieser Ähnlichkeit von einzelnen Methoden verwendet werden.

Beispiele (es geht nicht nur um visuelle Objekte):

Einstellungen von Formularelementen lassen sich per XML-Knoten konfigurieren oder können ihre Eigenschaften in einem XML-Knoten zurückliefern.

Formularelemente können Ausgang/Ziel einer Drag-and-Drop-Aktion sein.

Solche Dinge lassen sich viel besser handhaben, wenn man ein Objekt fragen kann, ob IIrgendwas unterstützt wird und dann IIrgendwas für die weitere Arbeit benutzt.

Die Referenzzählung ist dann zu nichts nütze und nichts weiter als lästig
  Mit Zitat antworten Zitat
Benutzerbild von uligerhardt
uligerhardt

Registriert seit: 19. Aug 2004
Ort: Hof/Saale
1.746 Beiträge
 
Delphi 2007 Professional
 
#14

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 27. Aug 2013, 08:42
Die Referenzzählung ist dann zu nichts nütze und nichts weiter als lästig
Ich benutze da folgende Basisklasse:
Delphi-Quellcode:
type
  TPureInterfacedObject = class(TObject, IInterface)
  protected
    { IInterface }
    function QueryInterface(const IID: TGUID; out Obj): HResult; virtual; stdcall;
    function _AddRef: Integer; stdcall;
    function _Release: Integer; stdcall;
  end;

{ TPureInterfacedObject }

function TPureInterfacedObject.QueryInterface(const IID: TGUID; out Obj): HResult;
begin
  Result := E_NOINTERFACE;
end;

function TPureInterfacedObject._AddRef: Integer;
begin
  Result := -1;
end;

function TPureInterfacedObject._Release: Integer;
begin
  Result := -1;
end;
Damit generiert der Compiler zwar immer noch Aufrufe für _AddRef und _Release, aber die töten das betroffene Objekt nicht.
Uli Gerhardt
  Mit Zitat antworten Zitat
Mikkey

Registriert seit: 5. Aug 2013
265 Beiträge
 
#15

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 27. Aug 2013, 09:15
Damit generiert der Compiler ...
Jetzt ist das Brett weg, vielen Dank.

Wenn die Sachen vom Compiler übernommen werden, ist es zwar immer noch überflüssig, aber nicht mehr lästig, es stört dann nicht mehr so sehr.

Bei Klassen, unter denen ohnehin TInterfacedObject liegt, muss es bisher auch funktioniert haben, bei den anderen habe ich dadurch, dass ich _Release selbst implementieren muss, ohnehin die Kontrolle.
  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 01:28 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