AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Fehlerhafter "never used"-Hinweis für private-Methoden bei Generics
Thema durchsuchen
Ansicht
Themen-Optionen

Fehlerhafter "never used"-Hinweis für private-Methoden bei Generics

Ein Thema von Bbommel · begonnen am 22. Apr 2024 · letzter Beitrag vom 25. Apr 2024
Antwort Antwort
Bbommel

Registriert seit: 27. Jun 2007
Ort: Köln
659 Beiträge
 
Delphi 12 Athens
 
#1

Fehlerhafter "never used"-Hinweis für private-Methoden bei Generics

  Alt 22. Apr 2024, 14:44
Delphi-Version: 5
Hallo alle,

ich glaube, ich bin tatsächlich über einen Compilerbug gestolpert. Aber da ich zum ersten Mal etwas ausführlicher selbst mit Generics gebastelt (und nicht nur das vorhandene genutzt) habe, bin ich mir nicht sicher, ob es nicht doch ein Denkfehler bei mir ist. Das Problem lässt sich auf folgenden, eigentlich recht überschaubaren Code reduzieren:

Delphi-Quellcode:
program generic_private_symbol;

{$APPTYPE CONSOLE}

{$R *.res}

uses
  System.SysUtils;

type

  TThing<T> = class
  private
    procedure DoSound;
  public
    procedure Sound; virtual;
  end;

  TSpecialThing<T> = class(TThing<T>)
  public
    procedure Sound; override;
  end;


{ TThing<T> }
procedure TThing<T>.DoSound;
begin
  writeln('tuuuuuuuut');
end;

procedure TThing<T>.Sound;
begin
  writeln('Don''t know how to horn');
end;

{ TSpecialThing<T> }

procedure TSpecialThing<T>.Sound;
begin
  writeln('Special thing makes noise!');
  DoSound;
end;

var
  myThing: TSpecialThing<integer>;

begin
  try
    { TODO -oUser -cConsole Main : Code hier einfügen }
    myThing:=TSpecialThing<integer>.Create;
    myThing.sound;
    readln;
    myThing.Free;
  except
    on E: Exception do
      Writeln(E.ClassName, ': ', E.Message);
  end;
end.
Startet man das Programm, dann erhält man völlig korrekt folgende Ausgabe:
Code:
Special thing makes noise!
tuuuuuuuut
Leider erhält man aber auch diesen Compilerhinweis:
Code:
[dcc32 Hinweis] generic_private_symbol.dpr(14): H2219 Das private-Symbol 'DoSound' wurde deklariert, aber nie verwendet
Dieser Hinweis ist ja falsch. Das private Symbol wird ja verwendet, nämlich in der abgeleiteten Klasse TSpecialThing, und, wie man in der Ausgabe sieht, ja auch erfolgreich aufgerufen. Macht man exakt das gleiche ohne Generics, dann erscheint keinerlei Hinweis, also so wie es sein soll.

Workaround übrigens, über den mein Kollege gestolpert ist: deklariert man die Methode "DoSound" als "virtual", dann ist der Compiler zufrieden und meckert nicht. Damit kann ich erstmal leben, aber ein Bug ist es doch trotzdem, oder? Oder sitzt das Problem doch vor dem Bildschirm?

(PS: Ja, die Generics machen in diesem reduzierten Beispiel nichts Sinnvolles - es geht nur darum, das Problem zu zeigen)
(PPS: Natürlich reiche ich das im neuen QP ein, wenn es tatsächlich ein Fehler ist)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

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

AW: Fehlerhafter "never used"-Hinweis für private-Methoden bei Generics

  Alt 22. Apr 2024, 14:54
Das compiliert nur wenn beide Klassen in derselben Unit stehen. Korrekt müsste DoSound protected sein.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Bbommel

Registriert seit: 27. Jun 2007
Ort: Köln
659 Beiträge
 
Delphi 12 Athens
 
#3

AW: Fehlerhafter "never used"-Hinweis für private-Methoden bei Generics

  Alt 22. Apr 2024, 15:04
Hm, okay. In dem Fall stehen ja beide Klassen in der selben Unit und die gleiche Bedingungen würde ja auch für "normale" (also ohne Generics) Klassen gelten, dennoch bekomme ich da den Hinweis ja nicht.

Aber ja, wenn ich den Teil als "protected" statt "private" deklariere, dann geht es, also Danke für den Hinweis.

Irgendwo hatte ich an anderer Stelle schon mal gelesen, dass die Sichtbarkeit von Methoden und Prozeduren im Zusammenhang mit Generics etwas anders/empflindlicher funktioniert. Man kann ja auch keine Funktion der gleichen Unit innerhalb einer Generics-Klasse benutzen, die nicht im Interface-Abschnitt veröffentlicht wurde. Hängt wahrscheinlich irgendwie zusammen.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Fehlerhafter "never used"-Hinweis für private-Methoden bei Generics

  Alt 22. Apr 2024, 16:31
Nja, du mußt bedenken, dass die Ableitung vor Ort gelinkt wird, wo der abgeleitete Typ deklariert ist
und an dieser Stelle muß er das Private auch sehn, sonst kann es rauchen, da aber es von dort nicht sehen dürfte.


Anstatt mit nur "private" kannst du es auch mal mit "strict private" versuchen, dann fällt sowas eher auf.
$2B or not $2B
  Mit Zitat antworten Zitat
Bbommel

Registriert seit: 27. Jun 2007
Ort: Köln
659 Beiträge
 
Delphi 12 Athens
 
#5

AW: Fehlerhafter "never used"-Hinweis für private-Methoden bei Generics

  Alt 25. Apr 2024, 15:01
Entschuldigt, dass ich erst jetzt noch einmal antworte - die letzten Tage war ich unterwegs und bin nicht zu einer Antwort gekommen. Ich denke, ich werde dazu in den nächsten Tagen einen Bugreport einreichen, denn auch eure Antworten haben mir jetzt nicht erklärt, warum dieser Compiler-Hinweis an der Stelle erscheinen sollte. Und vor allem ja nur dann, wenn die Klasse als generisch deklariert ist, sonst nicht.

In den bisherigen Antworten habt ihr zurecht darauf hingewiesen, dass die abgeleitete Klasse und die ursprüngliche Klasse in der gleichen Unit stehen müssen, wenn die abgeleitete Klasse auf eine private-Funktion der ursprünglichen Klasse zugreifen soll. Das ist völlig klar und hier ja auch der Fall. Daher kompiliert der Code ja auch völlig korrekt.

Was mich stört, ist ja nur der Compilier-Hinweis, der angibt, eine Prozedur sei nicht verwendet worden, obwohl sie verwendet wurde. Und dieser Hinweis erscheint eben nur bei generischen Klassen, aber nicht bei "normalen" Klassen. Mit dem Workaround, die betroffenen Methoden als "protected" zu deklarieren, kann ich in diesem Fall leben, aber richtig rund ist das ja nicht.

Vielleicht habe ich eure Antworten aber auch falsch verstanden, dann helft mir gerne noch einmal auf die Sprünge.
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

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

AW: Fehlerhafter "never used"-Hinweis für private-Methoden bei Generics

  Alt 25. Apr 2024, 15:18
Das Verhalten ist definitiv inkonsistent und das sollte behoben werden. Meine Antwort war lediglich als alternativer Workaround und Verbesserung der Maintenance gedacht.

Dessen ungeachtet halte ich persönlich aber die Verwendung von private Variablen und Methoden innerhalb derselben Unit für bedenklich.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Bbommel

Registriert seit: 27. Jun 2007
Ort: Köln
659 Beiträge
 
Delphi 12 Athens
 
#7

AW: Fehlerhafter "never used"-Hinweis für private-Methoden bei Generics

  Alt 25. Apr 2024, 15:30
Ah, okay, verstanden. Danke für die Rückmeldung!
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Fehlerhafter "never used"-Hinweis für private-Methoden bei Generics

  Alt 25. Apr 2024, 15:34
Dafür wurde ja das strict private erfunden, so als Bugfix für's private.

genauso wie man ForceQueue als Bugfix für das Queue erfunden hat
irgendwie seh ich da einen bedenklichen Trend
$2B or not $2B
  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 00:16 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