AGB  ·  Datenschutz  ·  Impressum  







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

class functions in interfaces?

Ein Thema von TurboMagic · begonnen am 28. Dez 2019 · letzter Beitrag vom 29. Dez 2019
Antwort Antwort
TurboMagic

Registriert seit: 28. Feb 2016
Ort: Nordost Baden-Württemberg
2.942 Beiträge
 
Delphi 12 Athens
 
#1

class functions in interfaces?

  Alt 28. Dez 2019, 18:50
Hallo,

mein Delphi 10.3.3 Compiler meckert, dass ich keine class functions in
Interfaces haben kann.

Warum eigentlich nicht, wenn die das Interface implementierende Klasse
die entsprechenden class functions implementiert?

Grüße
TurboMagic
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.624 Beiträge
 
Delphi 12 Athens
 
#2

AW: class functions in interfaces?

  Alt 28. Dez 2019, 18:56
Und wenn viele verschiedene Klassen das Interface implementieren, welche Klassenfunktion soll dann ausgeführt werden?
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von dummzeuch
dummzeuch

Registriert seit: 11. Aug 2012
Ort: Essen
1.603 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#3

AW: class functions in interfaces?

  Alt 28. Dez 2019, 19:50
Und wenn viele verschiedene Klassen das Interface implementieren, welche Klassenfunktion soll dann ausgeführt werden?
Wie bei anderen Methoden auch: Die, die das Interface implementiert:

Delphi-Quellcode:
type
  IMyInt = interface
    procedure bla;
    class function Blub: integer;
  end;

type
  TMyClass = class(TInterfacedObject, IMyInt)
  private
    procedure bla;
    class function Blub: integer;
  end;

var
  MyInt: IMyInt;
begin
  MyInt := TMyClass.Create;
  WriteLn(MyInt.Blub);
end;
Was natürlich nicht geht, ist die Klassenfunktion so aufzurufen:
  WriteLn(IMyInt.Blub);
Thomas Mueller
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.624 Beiträge
 
Delphi 12 Athens
 
#4

AW: class functions in interfaces?

  Alt 28. Dez 2019, 20:48
Ja eben
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.582 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: class functions in interfaces?

  Alt 28. Dez 2019, 21:30
Warum eigentlich nicht, wenn die das Interface implementierende Klasse
die entsprechenden class functions implementiert?
Aus mehreren Gründen.

Ein Grund ist, dass man an diese Klassenfunktion ja nur herankäme, indem man das Objekt hinter dem Interface ermittelt, den Klassentyp dieses Objekts und dann dynamisch den entsprechenden Aufruf auf dieser Klasse durchführt.
- Ein Problem dabei ist, dass man anders als bei dem Aufruf einer normalen Methode einer Klasse oder eines Interfaces dies nur über den Namen tun könnte. Man wäre also auf entsprechende RTTI-Informationen angewiesen.
- Das andere Problem ist, dass sich hinter einem Interface nicht unbedingt ein normales Delphi-Objekt aus dem selben Speichermanager verbergen muss. Das kann genauso gut ein aus einer DLL geladenes Objekt sein. Und die DLL muss noch nicht einmal in Delphi geschrieben sein. Das kann man rein über den Zeiger auf das Interface aber gar nicht sauber ermitteln.

Denn Interfaces sind ja keine Erfindung von Delphi. Ein solches Feature könnte man also nur überstülpen, nicht aber als Interfacefunktionalität hinzufügen.

Und der wichtigste Grund ist, dass es keinerlei logischen Grund gibt eine solche Funktionalität hinzuzufügen. Denn über das Interface kann so etwas ja nicht funktionieren, sondern nur über das dahinter liegende Objekt. Wenn man aber ein konkretes Objekt hat, gibt es keinen Grund für eine Klassenmethode. Man kann ja eine normale Interfacemethode nutzen und normal in der implementierenden Klasse implementieren, die dann eine Klassenmethode aufruft.
Sebastian Jänicke
Alle eigenen Projekte sind eingestellt, ebenso meine Homepage, Downloadlinks usw. im Forum bleiben aktiv!
  Mit Zitat antworten Zitat
TurboMagic

Registriert seit: 28. Feb 2016
Ort: Nordost Baden-Württemberg
2.942 Beiträge
 
Delphi 12 Athens
 
#6

AW: class functions in interfaces?

  Alt 29. Dez 2019, 09:58
Hm, zeigen nicht normale Methoden einerseits auf eine Speicheradresse an der deren Code liegt
und eine andere an der die Daten daer Objektinstanz liegen?

In so einem Fall müsste eine Klassenmethode doch einfach nur auf die Speicheradresse zeigen,
unter welcher der Code der Methode liegt und eine weitere die sich alle Instanzen der Klasse
teilen, damit der Code auf class vars zugreifen kann.

Ich sehe da nur einen geringen Unterschied drin...
Lediglich eben wie die einzelnen intern varwalteten Pointer zu initialisieren wären...
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.452 Beiträge
 
Delphi 12 Athens
 
#7

AW: class functions in interfaces?

  Alt 29. Dez 2019, 10:47
Eine Klassenmethode zeichnet sich dadurch aus, daß man keine Instanz der Klasse braucht um sie aufzurufen. Der vorangestellte Klassenname genügt. Weiterhin enthält der implizit übergebene Self-Parameter nicht die Instanz, wie bei normalen Methoden, sondern die Klasse.

Würde man nun Klassenmethoden in Interfaces zulassen, bieten sich zwei Anwendungs-Szenarien an:
  1. Ein Aufruf wie IMyInterface.MyClassMethod
  2. Die Implementierung einer Interface-Methode durch eine Klassenmethode

Punkt 1 scheidet offensichtlich mangels Zugriff auf eine implementierenden Klasse aus.

Punkt 2 scheitert an dem unterschiedlichen Self-Parameter. Einen Workaround dafür hatte Sebastian ja bereits beschrieben.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: class functions in interfaces?

  Alt 29. Dez 2019, 16:20
Jupp, Interfaces basieren auf Instantanzen von Objekten.

Bei Klassenmethoden gibt es keine Instanz, also auch keine Möglichkeit solche Methoden in einem Interface zu benutzen.



ABER, rein theoretisch bestünde die Möglichkeit in der Interface-Deklaration solche Methoden zu definieren. (also nicht im referenzierten Objekt, sondern im Interface selber ... ähnlich wie bei ClassHelpern)
Du kannst ja gerne mal erfolglos versuchen Embarcadero sowas zu vermitteln.

Solltest du es schaffen, dann sorge bitte auch dafür, dass wir endlich Makros bekommen.



Ich hab's nicht probiert, ob es überhaupt geht, aber wie wäre es mit einem Class-Helper für dein Interface?
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu (29. Dez 2019 um 16:23 Uhr)
  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 10:39 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