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
 
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
10.008 Beiträge
 
Delphi 12 Athens
 
#5

AW: class functions in interfaces?

  Alt 28. Dez 2019, 20: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
AppCentral
  Mit Zitat antworten Zitat
 


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 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz