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 1 von 2  1 2      
Mikkey

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

Schnittstelle ohne COM-Eigenschaft

  Alt 26. Aug 2013, 17:08
Es mag vielleicht banal klingen, aber in bin zuletzt aus der C#-Ecke gekommen und möchte gern die dort gewonnenen Design-Goodies auch als Delphi-Neuling weiterverwenden.

Wenn ich ein Interface deklariere, und in einer Klasse unsetze, verlangt der Compiler von mir, dass ich die IUnknown-Methoden implementiere. Ich habe aber gar nicht vor, COM-Objekte zu erstellen, sondern möchte eine Schnittstelle in verschiedenen Klassen verwenden, um sie auf einheitliche Weise ansprechen zu können.

Ebenso kann ich dabei die Release-Logik absolut nicht gebrauchen, lässt sich die abschalten?

Gibt es eine solche Möglichkeit in Delphi nicht?
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.159 Beiträge
 
Delphi 10 Seattle Enterprise
 
#2

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 26. Aug 2013, 17:13
Ich dachte, jedes Interface leitet sich erst einmal von IInterface ab? Solange du kein COM willst, sollte IUnknown da doch erst gar nicht ins Spiel kommen?

Das konkrete Objekt muss (eher: sollte), sobald es auch nur ein Interface implementiert, sich von TInterfacedObject als Elternklasse ableiten. Oder halt einer Klasse, die TInterfacedObject schon irgendwo als Vorfahr hat. Denn das implementiert die Standard-Interface-Methoden wie _Release bereits.

Oder habe ich was falsch verstanden?
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 16. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#3

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 26. Aug 2013, 17:22
Leider geht das nicht so einfach und reibungslos wie bei C#
Interfaces unter Delphi müssen immer von IUnknown oder IInterface (was das Gleiche ist) abgeleitet werden.
Damit du die Methoden von IUnknown nicht selbst implementieren musst, kannst du von der Klasse TInterfacedObject ableiten.

Wenn man einen Interfacezeiger hat ist es auch nur mit Klimmzügen möglich wieder an das eigentliche Klassenobjekt zu kommen.
Das bedeutet man kann ein Objekt, dass über ein Interface referenziert wird nicht einfach mit Free freigeben weil man über das Interface gar nicht an die Free-Methode herankommt.
Daraus folgt, dass man immer die Referenzzählung von IUnknown benutzen sollte (auch wenn man die Referenzzählung aushebeln kann und sie dabei aber weitere Schwierigkeiten einhandelt)
fork me on Github
  Mit Zitat antworten Zitat
Mikkey

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

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 26. Aug 2013, 17:23
Ich dachte, jedes Interface leitet sich erst einmal von IInterface ab? Solange du kein COM willst, sollte IUnknown da doch erst gar nicht ins Spiel kommen?
Ich habe IUnknown ja nicht verlangt, sondern der Compiler (das ist das Interface, das QueryInterface etc. enthält). Bei Delphi ist IUnknown halt mit IInterface bezeichnet.

Das konkrete Objekt muss (eher: sollte), sobald es auch nur ein Interface implementiert, sich von TInterfacedObject als Elternklasse ableiten. Oder halt einer Klasse, die TInterfacedObject schon irgendwo als Vorfahr hat. Denn das implementiert die Standard-Interface-Methoden wie _Release bereits.
Ich möchte bei den Klassen vielleicht eine andere Basisklasse haben bzw. habe keinen Einfluss auf deren Basisklasse, weil die Klassen bereits vorhanden sind.

Außerdem möchte ich gern vermeiden, dass der COM-Unterbau darunter ist. Bei C# geht das auch, warum muss Delphi unbedingt COM ins Spiel bringen.
  Mit Zitat antworten Zitat
Mikkey

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

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 26. Aug 2013, 17:30
Wenn man einen Interfacezeiger hat ist es auch nur mit Klimmzügen möglich wieder an das eigentliche Klassenobjekt zu kommen.
Das bedeutet man kann ein Objekt, dass über ein Interface referenziert wird nicht einfach mit Free freigeben weil man über das Interface gar nicht an die Free-Methode herankommt.
Daraus folgt, dass man immer die Referenzzählung von IUnknown benutzen sollte (auch wenn man die Referenzzählung aushebeln kann und sie dabei aber weitere Schwierigkeiten einhandelt)
Das bedeutet, die Delphi-Interfaces sind im Wortsinn gar keine Interfaces sondern COM-Objektbeschreibungen (wie bei C/C++)?

welche Möglichkeiten gibt es denn, die Interfaces wie Interfaces zu verwenden? Ich möchte gern Objekte verschiedener Klassen, die bestimmte Eigenschaften gemeinsam haben auch gemeinsam verwenden. C++ hat dafür die Mehrfachvererbung, C# die frei verwendbaren Interfaces. Das COM dabe die Objekte einfach wegschmeißt, darf dabei natürlich nicht passieren.
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 16. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#6

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 26. Aug 2013, 17:35
Außerdem möchte ich gern vermeiden, dass der COM-Unterbau darunter ist. Bei C# geht das auch, warum muss Delphi unbedingt COM ins Spiel bringen.
Tja, das geht halt nicht.
Der frühere Chefentwickler von Turbo Pascal & Delphi Anders Hejlsberg ist zu Microsoft gewechselt und dort die C# Entwicklung massgeblich voran getrieben.
C# ist im Prinzip ähnlich zu Delphi nur dass die Schwächen von Delphi in C# behoben wurden.
Interfaces wurden in Delphi erst nachträglich eingebaut.
Man merkt das unter anderem daran, dass die VCL Klassenbibliothek so gut wie keinen Gebrauch von Interfaces macht.
Interfaces sind in Delphi mehr oder weniger ein Fremdkörper geblieben.

Das bedeutet, die Delphi-Interfaces sind im Wortsinn gar keine Interfaces sondern COM-Objektbeschreibungen (wie bei C/C++)?
Das könnte man so sagen.
In Delphi sind Interfaces eine Einbahnstrasse.
Man kann einen Objektzeiger in einen Interfacezeiger umwandeln ( iz := meinobjekt as IMeinInterface ) aber die umgekehrte Richtung ist nicht vorgesehen.
fork me on Github
  Mit Zitat antworten Zitat
Mikkey

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

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 26. Aug 2013, 17:45
Außerdem möchte ich gern vermeiden, dass der COM-Unterbau darunter ist. Bei C# geht das auch, warum muss Delphi unbedingt COM ins Spiel bringen.
Tja, das geht halt nicht.
schade
Man merkt das unter anderem daran, dass die VCL Klassenbibliothek so gut wie keinen Gebrauch von Interfaces macht.
Naja, Windows-Forms benutzen AFAIR auch keine Interfaces.

In Delphi sind Interfaces eine Einbahnstrasse.
Man kann einen Objektzeiger in einen Interfacezeiger umwandeln ( iz := meinobjekt as IMeinInterface ) aber die umgekehrte Richtung ist nicht vorgesehen.
Das würde mich ja nicht stören, in C# kann man aus einer Interfacereferenz auch nur mittels Cast wieder zum Objekt kommen - ist ja auch nicht Sinn der Sache, auch wenn's wegen der RTTI sicher funktioniert:

iz = meinobjekt;

meinobjekt = iz as meineklasse;

Es geht mir nur darum, dass ich mir nicht eine Interfacereferenz hole und die mir dadurch, wenn ich sie nicht mehr brauche, das Objekt weghaut.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#8

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 26. Aug 2013, 17:52
Zitat:
Man merkt das unter anderem daran, dass die VCL Klassenbibliothek so gut wie keinen Gebrauch von Interfaces macht.
FMX dafür um so mehr
Markus Kinzler
  Mit Zitat antworten Zitat
Mikkey

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

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 26. Aug 2013, 18:19
Um mal in die Richtung Konstruktivität zu kommen...

Kann ich dort, wo ich meine Klassen erzeuge (und wo sie später irgendwann entfernt werden sollen) den Referenzzähler um eins erhöhen und dort, wo das Objekt definitiv nicht mehr gebraucht wird, diesen Referenzzähler herunterzählen?

So wäre sichergestellt, dass das Objekt nicht ausversehen ins Nirwana verschwindet.

Oder kann ich in meinen Klassen den Referenzzähler komplett ignorieren und den Free auf das Objekt weiterverwenden? Wäre mir ehrlich gesagt am liebsten.
  Mit Zitat antworten Zitat
r2c2

Registriert seit: 9. Mai 2005
Ort: Nordbaden
925 Beiträge
 
#10

AW: Schnittstelle ohne COM-Eigenschaft

  Alt 26. Aug 2013, 21:19
Kann ich dort, wo ich meine Klassen erzeuge (und wo sie später irgendwann entfernt werden sollen) den Referenzzähler um eins erhöhen und dort, wo das Objekt definitiv nicht mehr gebraucht wird, diesen Referenzzähler herunterzählen?
Ja. Dafür sind die Methoden verantwortlich, die du von IUnknown erbst und in TInterfacedObject für dich implementiert sind.

Zitat:
Oder kann ich in meinen Klassen den Referenzzähler komplett ignorieren und den Free auf das Objekt weiterverwenden? Wäre mir ehrlich gesagt am liebsten.
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.

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.


mfg

Christian
Kaum macht man's richtig, schon klappts!
  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:37 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