Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi (Falsche?) Warnung beim Überladen eines Konstruktors (https://www.delphipraxis.net/200982-falsche-warnung-beim-ueberladen-eines-konstruktors.html)

Neutral General 13. Jun 2019 13:27

Delphi-Version: 10.2 Tokyo

(Falsche?) Warnung beim Überladen eines Konstruktors
 
Hallo,

Habe vereinfacht folgende Situation (Delphi 10.3.0):
Delphi-Quellcode:
type
  TBasis = class
  public
    constructor Create(AOwner: TComponent); virtual;
  end;

  TAbleitung = class(TBasis)
  public
    constructor Create(AOwner: TComponent; A, B: String); overload; // [dcc32 Warnung] Unit4.pas(24): W1010 Methode 'Create' verbirgt virtuelle Methode vom Basistyp 'TBasis'
  end;
Ich verstehe nicht warum da eine Warnung kommt. Ich füge in der Ableitung einfach einen zweiten constructor per overload hinzu.
Der sollte nichts verbergen und auch wenn ich das teste, kann ich im Code beide constructoren aufrufen (funktioniert auch zur Laufzeit):
Delphi-Quellcode:
// Beides compiliert und läuft.
var ableitung: TAbleitung;
begin
  ableitung := TAbleitung.Create(nil);
  ableitung := TAbleitung.Create(nil, 'A', 'B');
Die Codevervollständigung zeigt korrekt beide Überladungen an, beide Überladungen kompilieren und verhalten sich auch zur Laufzeit wie man das erwartet würde.
Warum also dann die Warnung? Gibts da irgendwas was ich übersehe oder ist die Warnung an der Stelle (wie ich vermute) einfach falsch?

Wenn ich den constructor in TBasis NICHT virtuell mache, dann meckert der Compiler übrigens nicht.

Schokohase 13. Jun 2019 13:38

AW: (Falsche?) Warnung beim Überladen eines Konstruktors
 
Delphi-Quellcode:
reintroduce
http://docwiki.embarcadero.com/RADSt...thoden_(Delphi)

Neutral General 13. Jun 2019 13:45

AW: (Falsche?) Warnung beim Überladen eines Konstruktors
 
Zitat:

Zitat von Schokohase (Beitrag 1434558)

Ich kenne reintroduce, aber das ist ein ganz anderer Fall.
Es geht hier ja explizit darum einen 2. Konstruktor hinzuzufügen (eine Überladung) und nicht den Konstruktor der Basisklasse mit reintroduce zu überdecken.
Und das klappt ja auch - nur halt mit einer Warnung die ich nicht nachvollziehen kann.

Schokohase 13. Jun 2019 14:02

AW: (Falsche?) Warnung beim Überladen eines Konstruktors
 
Delphi-Quellcode:
type
  TBasis = class
  public
    constructor Create(AOwner: TComponent); virtual;
  end;

  TAbleitung = class(TBasis)
  public
    constructor Create(AOwner: TComponent); overload; override;
    constructor Create(AOwner: TComponent; A,B: string); reintroduce; overload;
  end;

{ TBasis }

constructor TBasis.Create(AOwner: TComponent);
begin
  inherited Create;

end;

{ TAbleitung }

constructor TAbleitung.Create(AOwner: TComponent);
begin
  inherited;

end;

constructor TAbleitung.Create(AOwner:TComponent; A,B: string);
begin
  inherited Create(AOwner);

end;

Neutral General 13. Jun 2019 14:08

AW: (Falsche?) Warnung beim Überladen eines Konstruktors
 
Dann hab ich für TAbleitung 3 Konstruktoren (2x (AOwner: TComponent)).

Aber so klappt es:
Delphi-Quellcode:
type
  TBasis = class
  public
    constructor Create(AOwner: TComponent); virtual;
  end;

  TAbleitung = class(TBasis)
  public
    constructor Create(AOwner: TComponent; A,B: string); reintroduce; overload;
  end;

Schokohase 13. Jun 2019 14:27

AW: (Falsche?) Warnung beim Überladen eines Konstruktors
 
Zitat:

Zitat von Neutral General (Beitrag 1434570)
Dann hab ich für TAbleitung 3 Konstruktoren (2x (AOwner: TComponent)).

Jupp, so hatte ich es auch zuerst, aber dann hat mein Rio rumgesponnen und zeigte mir nur diesen einen Konstruktor an.

Ich halte es eh für seltsam dass die Konstruktoren automatisch weitervererbt werden. Das machen andere Sprachen anders (und mMn auch besser).

Egal, es läuft ja (irgendwie).

Der schöne Günther 13. Jun 2019 16:43

AW: (Falsche?) Warnung beim Überladen eines Konstruktors
 
Zitat:

Zitat von Schokohase (Beitrag 1434574)
Egal, es läuft ja (irgendwie).

The Delphi Way of Life

Codehunter 13. Jun 2019 23:36

AW: (Falsche?) Warnung beim Überladen eines Konstruktors
 
Ähm... Wer sagt denn dass ein Constructor unbedingt "Create" heißen muss? Nenn den in der Kindklasse eben "CreateNew", was ja nicht unüblich ist.

Oder alternativ, den Konstruktor der Basisklasse einfach gar nicht erst virtual deklarieren. Die besagte Compilerwarnung hat schon ihre Berechtigung. Denn es hindert dich ja nichts daran, in der Kindklasse einen Konstruktor mit identischer Parameterliste wie in der Elternklasse zu deklarieren. Spätestens dann hättest du ein Scope-Problem.

Der scheinbar vererbte Konstruktor wird dir auch nur in der selben Unit in beiden Varianten in der Codevervollständigung angezeigt. In einer anderen Unit erscheint nur der Konstruktor der Kindklasse. Ist wohl die selbe "Baustelle" wie die Tatsache, dass man in der selben Unit auch in Kindklassen auf private-Variablen der Elternklasse zugreifen kann.

Besser man gewöhnt sich so einen Schluderladen aus überladenen virtuellen Konstruktoren gar nicht erst an. Denn in der Praxis kann man meistens nur einen davon gebrauchen weil der andere die Kindklasse gar nicht richtig initialisiert.

Stevie 14. Jun 2019 09:18

AW: (Falsche?) Warnung beim Überladen eines Konstruktors
 
Hat Himitsu schon vor Jahren mal eingetragen und wurde als "Works as expected" geschlossen: https://quality.embarcadero.com/browse/RSP-11165

Neutral General 14. Jun 2019 09:28

AW: (Falsche?) Warnung beim Überladen eines Konstruktors
 
Liste der Anhänge anzeigen (Anzahl: 2)
Zitat:

Zitat von Codehunter (Beitrag 1434603)
Ähm... Wer sagt denn dass ein Constructor unbedingt "Create" heißen muss? Nenn den in der Kindklasse eben "CreateNew", was ja nicht unüblich ist.

Technisch gesehen hast du Recht. In der Praxis wird mir schlecht wenn ich Konstruktoren sehe, die nicht "Create" heißen.

Zitat:

Zitat von Codehunter (Beitrag 1434603)
Oder alternativ, den Konstruktor der Basisklasse einfach gar nicht erst virtual deklarieren. Die besagte Compilerwarnung hat schon ihre Berechtigung. Denn es hindert dich ja nichts daran, in der Kindklasse einen Konstruktor mit identischer Parameterliste wie in der Elternklasse zu deklarieren. Spätestens dann hättest du ein Scope-Problem.

Das hier ist nur ein Beispiel. Im Original ist TBasis eine Ableitung von TComponent, bei der der constructor Create(AOwner: TComponent) nunmal virtuell ist.
Die Compilerwarnung hat NUR DANN eine Berechtigung wenn ich in der Ableitung tatsächlich einen Konstruktor definiere mit den gleichen Parametern wie er schon in der/einer Elternklasse existiert.
Das ist aber hier nicht der Fall, daher kein Scope Problem und keinen Grund für die Warnung.

Zitat:

Zitat von Codehunter (Beitrag 1434603)
Der scheinbar vererbte Konstruktor wird dir auch nur in der selben Unit in beiden Varianten in der Codevervollständigung angezeigt. In einer anderen Unit erscheint nur der Konstruktor der Kindklasse. Ist wohl die selbe "Baustelle" wie die Tatsache, dass man in der selben Unit auch in Kindklassen auf private-Variablen der Elternklasse zugreifen kann.

Das ist schlichtweg falsch:

Formular:
https://www.delphipraxis.net/attachm...1&d=1560500618

Unit4:
https://www.delphipraxis.net/attachm...1&d=1560500648

Zitat:

Zitat von Codehunter (Beitrag 1434603)
Besser man gewöhnt sich so einen Schluderladen aus überladenen virtuellen Konstruktoren gar nicht erst an. Denn in der Praxis kann man meistens nur einen davon gebrauchen weil der andere die Kindklasse gar nicht richtig initialisiert.

Das kann man so auch nicht verallgemeinern.
In den meisten Fällen hast du Recht, aber es gibt eben auch Fälle wo der Konstruktor des Kinds nur ein "Bonus" ist und auch der Elternkonstruktor das Objekt ausreichend initialisiert.


Alle Zeitangaben in WEZ +1. Es ist jetzt 19:37 Uhr.
Seite 1 von 2  1 2      

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