AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi override - overload - reintroduce - virtual
Thema durchsuchen
Ansicht
Themen-Optionen

override - overload - reintroduce - virtual

Ein Thema von cn-tools · begonnen am 26. Mai 2010 · letzter Beitrag vom 26. Mai 2010
Antwort Antwort
Seite 1 von 2  1 2      
cn-tools

Registriert seit: 23. Mär 2003
15 Beiträge
 
Delphi 10.3 Rio
 
#1

override - overload - reintroduce - virtual

  Alt 26. Mai 2010, 10:02
Hi @ all!

Könnte mir bitte jemand auf die Sprünge helfen bzw. sagen ob das überhaupt funktioniert?

Delphi-Quellcode:
TModelKlasseA = class(TObject)
end;
TModelKlasseB = class(TModelKlasseA)
end;

TKlasseA = class(TObjec)
  function GetMD: TModelKlasseA; virtual; abstract;
end;

TKlasseB = class(TKlasseA)
  function GetMD: TModelKlasseB; ????????
end;

Was muss ich bei TKlasseB.GetMD hinten angeben dass Delphi das richtig macht?
Das Programm soll, wenn TKlasseA.GetMD aufgerufen wird, die Methode TKlasseB.GetMD aufrufen.

thx@all4help
DANKE

lg aus Österreich
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: override - overload - reintroduce - virtual

  Alt 26. Mai 2010, 10:08
virtual und dynamic besagen, daß diese Methode in Nachfahren überschreibbar ist

override sagt, daß diese Methode eine virtuelle/dynamische Methode eines Vorfahren überschreiben soll

abstract besagt, daß diese virtuelle/dynamische Mathode in der "ausgangsklasse" zwar deklariert, aber nicht implementiert ist.

overload besagt, daß es eine gleichnamige Methode gibt (natürlich mit anderen Parametern)
und diese paralell/alternativ aufrufbar sind

mit reintroduce sagt man, daß es in den Vorfahren eine gleichnamige Methode gibt,
man diese aber "absichtlich" verdecken will. (ohne reintroduce würde der Compiler eine entsprechende Warnung anzeigen



Lösung deines Problems: override
[edit] stümmt , also reintroduce und ohne virtual


[add]
http://www.delphi-treff.de/object-pa...akte-methoden/
$2B or not $2B
  Mit Zitat antworten Zitat
schlecki

Registriert seit: 11. Apr 2005
Ort: Darmstadt
148 Beiträge
 
Delphi XE2 Enterprise
 
#3

Re: override - overload - reintroduce - virtual

  Alt 26. Mai 2010, 10:11
Zitat von himitsu:
Lösung deines Problems: override
Nicht ganz, da sich der Rückgabetyp der Funktion geändert hat. Richtig wäre hier reintroduce, welches besagt, dass sich die Signatur der überschriebenen Methode verändert hat (wobei der Rückgabetyp eigentlich nicht zur Signatur gehört)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: override - overload - reintroduce - virtual

  Alt 26. Mai 2010, 10:26
Stimm, hast Recht.

OK, Aufrufsignatur gehört der nicht, aber zur Gesamten schon.


Delphi-Quellcode:
TModelKlasseA = class(TObject)
end;
TModelKlasseB = class(TModelKlasseA)
end;

TKlasseA = class(TObjec)
  function GetMD: TModelKlasseA;
end;

TKlasseB = class(TKlasseA)
  function GetMD: TModelKlasseB; reintroduce;
end;

function TKlasseA.GetMD: TModelKlasseA;
begin
  result := TModelKlasseA.Create;
end;

function TKlasseB.GetMD: TModelKlasseB;
begin
  result := TModelKlasseB.Create;
end;

Ich würde es dennoch mit Override lösen,
wobei hier TKlasseB dennoch TModelKlasseB ausliefen kann, da diese ja von TModelKlasseA abgeleitet ist.
Delphi-Quellcode:
TModelKlasseA = class(TObject)
end;
TModelKlasseB = class(TModelKlasseA)
end;

TKlasseA = class(TObjec)
  function GetMD: TModelKlasseA; virtual; abstract;
end;

TKlasseB = class(TKlasseA)
  function GetMD: TModelKlasseA; override;
end;

// TKlasseA.GetMD ist nicht implementiert

function TKlasseB.GetMD: TModelKlasseA;
begin
  result := TModelKlasseB.Create;
end;
Delphi-Quellcode:
TModelKlasseA = class(TObject)
end;
TModelKlasseB = class(TModelKlasseA)
end;

TKlasseA = class(TObjec)
  function GetMD: TModelKlasseA; virtual;
end;

TKlasseB = class(TKlasseA)
  function GetMD: TModelKlasseA; override;
end;

function TKlasseA.GetMD: TModelKlasseA;
begin
  result := TModelKlasseA.Create;
end;

function TKlasseB.GetMD: TModelKlasseA;
begin
  result := TModelKlasseB.Create;
end;
$2B or not $2B
  Mit Zitat antworten Zitat
Benutzerbild von mleyen
mleyen

Registriert seit: 10. Aug 2007
609 Beiträge
 
FreePascal / Lazarus
 
#5

Re: override - overload - reintroduce - virtual

  Alt 26. Mai 2010, 10:47
Zitat von cn-tools:
Das Programm soll, wenn TKlasseA.GetMD aufgerufen wird, die Methode TKlasseB.GetMD aufrufen.
Ich glaube du meintest es andersrum:
Das Programm soll, wenn TKlasseB.GetMD aufgerufen wird, die Methode TKlasseA.GetMD aufrufen.
Ansonsten müsstest du nochmal TKlasseB in TKlasseA instanziieren, solange TKlasseB von TKlasseA abgeleitet ist.
  Mit Zitat antworten Zitat
cn-tools

Registriert seit: 23. Mär 2003
15 Beiträge
 
Delphi 10.3 Rio
 
#6

Re: override - overload - reintroduce - virtual

  Alt 26. Mai 2010, 10:58
Danke erstmal @ all für die schnellen Antworten ... bin gerade am abarbeiten eurer Vorschläge

@mleyen:
ich meinte eigentlich wenn in der Klasse "TKlasseA" die Methode "GetMD " aufgerufen wird.
Somit soll das Programm - weil in TKlasseA ist die Mehtode ja ABSTRACT - die Methode von TKlasseB aufrufen.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: override - overload - reintroduce - virtual

  Alt 26. Mai 2010, 11:22
Zitat von cn-tools:
ich meinte eigentlich wenn in der Klasse "TKlasseA" die Methode "GetMD " aufgerufen wird.
Somit soll das Programm - weil in TKlasseA ist die Mehtode ja ABSTRACT - die Methode von TKlasseB aufrufen.
Dann mußt es natürlich virtual/dynamic + override sein, aber bei sowas darf sich die Signatur nicht ändern.
$2B or not $2B
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#8

Re: override - overload - reintroduce - virtual

  Alt 26. Mai 2010, 11:40
Es fehlt ein Stichwort : inherited; Ich würde es so programmieren :
Delphi-Quellcode:
TKlasseA = class(TObject)
  function GetMD: TModelKlasseA; virtual; // überschreibbar machen
end;

TKlasseB = class(TKlasseA)
  function GetMD: TModelKlasseB; override; // Vorgänger wird überschrieben
end;
..
function TKlasseA.GetMD: TModelKlasseA;
begin
// vorerst mal leer, kann/wird sich aber ändern. Nötig, weil abstract fehlt.
// wird abstract gewünscht, dann besser die function für TKlasseA wegen Überflüssigkeit
// gleich weglassen und erst in TKlasseB einführen. Ausnahme : es handelt sich um eine Komponentenklasse,
// die verkauft werden soll etc.
end;

function TKlasseB.GetMD: TModelKlasseB;
begin
  inherited; // zuerst GetMD von TKlasseA ausführen. Wird das weggelassen, dann wird TKlasseA.GetMD NICHT ausgeführt
// der Krempel, den TKlasseB zusätzlich zu TKlasseA noch braucht
end;
Also nochmals im Klartext : auf abstract verzichten und lieber leere Methode einbauen, die sofort eingesetzt werden kann, selbst wenn sie anfangs nichts macht. Macht mans anders, dann ist die Gefahr ziemlich hoch, sich dauernd "abstracte" Compiler-Fehlermeldungen einzufangen.
Gruß
Hansa
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: override - overload - reintroduce - virtual

  Alt 26. Mai 2010, 11:51
Oder man macht es richtig! Den die Verwendung von abstrakten Methoden macht Sinn. Bei neueren Delphiversionen kann man zudem mit strikt abstrakte Methoden nehmen ( Fehler nicht erst zur Laufzeit bei Zugriff)
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: override - overload - reintroduce - virtual

  Alt 26. Mai 2010, 11:57
Zitat von mkinzler:
Oder man macht es richtig! Den die Verwendung von abstrakten Methoden macht Sinn. Bei neueren Delphiversionen kann man zudem mit strikt abstrakte Methoden nehmen ( Fehler nicht erst zur Laufzeit bei Zugriff)
Selbst die älteren Compiler geben aber zumindestens Warnungen aus.

Und wie mkinzler schon richtig sagte, sind abstrakte Methoden nicht zu verachten, jedenfalls wenn sie in Basis-Klassen liegen, welche selber niemals direkt instantiirt werden ... die quasi nur eine gemeinsame Schnittelle definieren, wie z.B. TStrings.
Vorteil hierbei ist nämlich, daß der Compiler sich dann meldet, wenn man was in der Ableitung vergißt zu implementieren.
(bei den leeren Methoden würde man sich frühestens zur Laufzeit wunden, wenn irgendwas aus unerklärlichen Gründen nicht so läuft, wie gewollt)
$2B or not $2B
  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 23:19 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 by Thomas Breitkreuz