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 "Abstrakter Fehler" schon zur Compile-Zeit unterbinden (https://www.delphipraxis.net/143321-abstrakter-fehler-schon-zur-compile-zeit-unterbinden.html)

DelphiBandit 13. Nov 2009 10:28


"Abstrakter Fehler" schon zur Compile-Zeit unterbi
 
Hallo zusammen,

wenn ich eine Grundklasse mit abstrakten virtuellen Methoden ableite und diese dann in der erbenden Klasse nicht deklariere, bekomme ich den Fehler erst als Laufzeitfehler "Abstrakter Fehler" mitgeteilt.

Gibt es keine Möglichkeit den Compiler (hier RS 2007) zu überreden mich auf solche Unstimmigkeiten hinzuweisen? Bekomme eine Warnung vom Compiler, dass eine Instanz mit abstrakten Methoden angelegt wird. Aber keinen Compiler-Fehler. Oder ein Keyword was eine Ableitung zwingend erforderlich macht?

Andere Möglichkeit wäre der Einsatz eines Interface, dieses macht die Implementierung in den nutzenden Objekten erforderlich, aber das ist mir ein wenig viel Overhead mit der internen Zählung etc. Eigentlich nicht notwendig für meine einfachen Objekte.

Bin für jeden Tipp dankbar

Carsten

----
Beispiel (nein, aase normalerweise nicht mit globalen Var's und initialization/finalization herum - wollte mir nur weitere Events wie OnCreate sparen) -> siehe //

Delphi-Quellcode:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls;

type
  TGrundklasse = class(TObject)
    private
       function FunktionEins: Boolean; virtual; abstract;
  end;

  TAbleitung = class(TGrundklasse)
    private
       function FunktionEins: Boolean; override; // Diese Zeile kommentieren -> "Abstrakter Fehler"
  end;

  TForm1 = class(TForm)
    btn1: TButton;
    procedure btn1Click(Sender: TObject);
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
  end;

var
  Form1: TForm1;
  tobj: TAbleitung;

implementation

{$R *.dfm}

procedure TForm1.btn1Click(Sender: TObject);
begin
   tobj.FunktionEins;
end;

{ TAbleitung }
// Hier auch kommentieren
function TAbleitung.FunktionEins: Boolean;
begin
  MessageDlg('Funktion ist deklariert und funktioniert', mtInformation, [mbOK], 0);
  Result := True;
end;

initialization
  tobj := TAbleitung.Create;

finalization
  tobj.Free;

end.

himitsu 13. Nov 2009 10:41

Re: "Abstrakter Fehler" schon zur Compile-Zeit unt
 
[edit]
*was falsch verstanden*

mkinzler 13. Nov 2009 10:42

Re: "Abstrakter Fehler" schon zur Compile-Zeit unt
 
Deklariere die Klasse als abstrakt und nicht die Methode
(Bin mir aber nicht sicher, mit welcher Version von Delphi diese Möglichkeit kam)

sirius 13. Nov 2009 10:56

Re: "Abstrakter Fehler" schon zur Compile-Zeit unt
 
Zitat:

Zitat von himitsu
Einfache und sogar die offizielle Lösung: definiere die abstrakten Methoden ... notfalls einfach leer (ohne Code) lassen.

Mit einer abstrakten Methode möchte man aber gerade den Entwickler dazu zwingen, diese Methode zu implementieren. Und eine Warnung gibt es ja. Wer Warnungen ignoriert ist selber Schuld.

@mkinzler: TGrundklasse wäre abstrakt, aber TAbleitung ja nicht mehr.


Ich frag mich: Was hat der Compiler eigentlich für Chancen abstrakte Fehler zu erkennen. Teilweise könnt er hinbekommen, wie hier, wenn die Klasse direkt instanziert wird. aber anscheinend geht Delphi den Weg, den Nutzer einfach nur zu warnen, vielleicht braucht er ja die abstrakten Methoden nicht.
Aber welche Chance hat Delphi, wenn du eine abstrakte Klasse aus einer Metaklasse heraus erzeugst? Keine! Da gibt es auch keine Compilerwarnung.
Ich würde sage, hier reicht es, wenn der Entwickler einmal mitdenkt.

DelphiBandit 13. Nov 2009 11:00

Re: "Abstrakter Fehler" schon zur Compile-Zeit unt
 
Zitat:

Zitat von himitsu
Einfache und sogar die offizielle Lösung: definiere die abstrakten Methoden ... notfalls einfach leer (ohne Code) lassen.

OK, verstehe das mal als: Einfach aufpassen und alles implementieren! Und ab und zu einen Blick in die Compiler-Warnings werfen. Schade, hatte die Hoffnung, dass es eine Compiler-Direktive gibt, die einem dieses Konstrukt verbietet.

Danke erstmal

himitsu 13. Nov 2009 11:07

Re: "Abstrakter Fehler" schon zur Compile-Zeit unt
 
Neee, hatte es etwas falsch verstanden.

Komisch, denn eigentlich sollte der Compiler hier nicht meckern,

es sei denn du versuchst irgendwo eine Instanz von TGrundklasse zu erzeugen, auf was die Fehlermeldung hinweisen würde. :gruebel:


In welcher Zeile meckert denn Delphi und wie sieht diese Zeile aus?

uligerhardt 13. Nov 2009 11:58

Re: "Abstrakter Fehler" schon zur Compile-Zeit unt
 
Zitat:

Zitat von HondaGL1
Zitat:

Zitat von himitsu
Einfache und sogar die offizielle Lösung: definiere die abstrakten Methoden ... notfalls einfach leer (ohne Code) lassen.

OK, verstehe das mal als: Einfach aufpassen und alles implementieren! Und ab und zu einen Blick in die Compiler-Warnings werfen. Schade, hatte die Hoffnung, dass es eine Compiler-Direktive gibt, die einem dieses Konstrukt verbietet.

Mit neueren Delphiversionen (ab D2009?) könnte das funktionieren:
Delphi-Quellcode:
{$WARN CONSTRUCTING_ABSTRACT ERROR}
Kann's leider nicht ausprobieren, da wir bei D2007 hängengeblieben sind.

DelphiBandit 16. Nov 2009 07:19

Re: "Abstrakter Fehler" schon zur Compile-Zeit unt
 
Zitat:

Zitat von uligehardt
Mit neueren Delphiversionen (ab D2009?) könnte das funktionieren:
Delphi-Quellcode:
{$WARN CONSTRUCTING_ABSTRACT ERROR}
Kann's leider nicht ausprobieren, da wir bei D2007 hängengeblieben sind.

Danke für den Tipp, aber wir arbeiten auch nur mit D2007. Werde ich aber @home mal probieren, dort nutze ich die neuere Version.

Zitat:

Zitat von himitusu
In welcher Zeile meckert denn Delphi und wie sieht diese Zeile aus?

Gemeckert wird zur Laufzeit in Zeile 40 (logisch), das Warning bezieht sich bei auskommentierter Ableitung auf das Create im Initialization-Abschnitt.

Wenn das nicht geht ist es auch kein Drama! Hatte nur die Hoffnung ich kann uns mit einer Compiler-Einstellung das Leben ein wenig erleichtern. Ansonsten hat sirius natürlich Recht.

Neutral General 24. Apr 2012 23:21

AW: "Abstrakter Fehler" schon zur Compile-Zeit unterbinden
 
Hallo,

Der Thread ist zwar schon etwas älter aber ich habe quasi das gleiche "Problem".
Ich hätte gerne, dass der Compiler einen Fehler meldet, wenn ich in einer abgeleiteten Klasse eine abstrakte Methode nicht überschrieben habe.
Also quasi wie wenn man eine Methode eines benutzten Interfaces nicht implementiert.

Gibt es da mittlerweile (in den neuen Delphi Versionen) eine Möglichkeit?
Dieses

Delphi-Quellcode:
{$WARN CONSTRUCTING_ABSTRACT ERROR}
Hat bei mir nicht funktioniert. Es sei denn ich habe irgendwas falsch gemacht...

himitsu 24. Apr 2012 23:48

AW: "Abstrakter Fehler" schon zur Compile-Zeit unterbinden
 
In XE2 funktiniert Folgendes ganz gut.

Delphi-Quellcode:
{$WARN CONSTRUCTING_ABSTRACT ERROR}   // Error

{$WARN CONSTRUCTING_ABSTRACT ON}      // Warning (Standard)

{$WARN CONSTRUCTING_ABSTRACT OFF}     // Nix
Also dort, wo man versucht eine Klasseninstanz zu erstellen.
Aber natürlich nur dort, wo man das Create direkt über den Typ aufruft.
Delphi-Quellcode:
TMyAbstractClass.Create; // Fehler

C := TMyAbstractClass;
C.Create; // nix
Ob und bis zu welchem Delphi es runter geht ... kann ich erst später sagen.

[edit]
Ab D2009 gibt es keine Probleme. (ERROR funktionierte überall)
Davor (in 2007) ist nur ON und OFF verfügbar.


Alle Zeitangaben in WEZ +1. Es ist jetzt 05:53 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