Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Vordefinierte Parameter nur im Interface-Abschnitt? (https://www.delphipraxis.net/189677-vordefinierte-parameter-nur-im-interface-abschnitt.html)

Codehunter 11. Jul 2016 07:45

AW: Vordefinierte Parameter nur im Interface-Abschnitt?
 
Zitat:

Zitat von jaenicke (Beitrag 1342301)
Mir ist allerdings damals schon kein Grund eingefallen warum man diese Verwirrungstaktik betreiben sollte und die Parameter weglassen sollte. Ein Überblick über fremden Quelltext wird dadurch deutlich verzögert und auch in eigenem Quelltext ist es der Lesbarkeit deutlich abträglich.

Womit sich quasi schon zwangsläufig die Frage aufdrängt: Warum lässt die Klassenvervollständigung das dann per Default weg und kann man dieses Verhalten umkonfigurieren?
Zitat:

Zitat von jaenicke (Beitrag 1342301)
Natürlich erkennt man Parameter in sauberem Quelltext zumindest an dem großen A als Prefix, aber den Typ sieht man daran dennoch nicht.

Jetzt wo du das ansprichst, wirft das bei mir gleich die nächste Frage auf: Das "A" am Anfang jedes Parameternamen scheint wohl nur bei Prozeduren und Funktionen üblich zu sein, nicht jedoch bei Eventhandlern (procedure of object). Zumindest sieht man bei den allerwenigsten VCL-Klassen so ein führendes A in Eventhandlern.

Ich wünsche allen einen guten Start in die Woche.

Uwe Raabe 11. Jul 2016 08:42

AW: Vordefinierte Parameter nur im Interface-Abschnitt?
 
Zitat:

Zitat von Codehunter (Beitrag 1342331)
Womit sich quasi schon zwangsläufig die Frage aufdrängt: Warum lässt die Klassenvervollständigung das dann per Default weg und kann man dieses Verhalten umkonfigurieren?

Die Parameter werden ja gar nicht weggelassen - nur die Default-Werte.

Codehunter 11. Jul 2016 09:51

AW: Vordefinierte Parameter nur im Interface-Abschnitt?
 
Zitat:

Zitat von Uwe Raabe (Beitrag 1342333)
Die Parameter werden ja gar nicht weggelassen - nur die Default-Werte.

Genau darauf bezog sich ja meine Eingangsfrage. Die Parameter wegzulassen hat Sir Rufo in den Raum gestellt, nicht ich ^^

himitsu 11. Jul 2016 11:26

AW: Vordefinierte Parameter nur im Interface-Abschnitt?
 
AOwner im Create, bei TComponent ... also doch mit A

Das ist nunmal keine "feste" Regel,
aber es gibt mehrere "Vorschlage" von irgendwelchen Delphi-Gurus, wie man es machen können sollte.

Sherlock 11. Jul 2016 12:07

AW: Vordefinierte Parameter nur im Interface-Abschnitt?
 
Das Create ist ja nicht so sehr ein Eventhandler wie ein Constructor...würde ich mal ganz keck behaupten.

Sherlock

jaenicke 11. Jul 2016 12:20

AW: Vordefinierte Parameter nur im Interface-Abschnitt?
 
Zitat:

Zitat von Codehunter (Beitrag 1342331)
Womit sich quasi schon zwangsläufig die Frage aufdrängt: Warum lässt die Klassenvervollständigung das dann per Default weg und kann man dieses Verhalten umkonfigurieren?

Ich meinte damit vor allem die Parameter an sich. Die Defaultwerte sind in der Tat nicht ganz so wichtig zum Verständnis, da alle Werte korrekt behandelt werden sollten.

Man erkennt daran ja vor allem so etwas wie -1 heißt "kein Eintrag" und größer oder gleich Null ist der Index oder die Nummer eines Eintrags. An der Stelle ist natürlich dann interessant, ob der Wert für "kein Eintrag" Null oder -1 ist, wenn das nicht anderswo dokumentiert ist, aber normalerweise sollte das auch im Quelltext sofort klar werden (anders als die Bedeutung und der Typ eines Parameters).

Trotzdem schreibe ich die Defaultwerte zu Dokumentationszwecken immer dazu.

Codehunter 12. Jul 2016 07:29

AW: Vordefinierte Parameter nur im Interface-Abschnitt?
 
Bzgl. Default-Werte im Implementation-Abschnitt: Ich habe jetzt mal eine Runde "gehirnt" warum ich das gewohnheitsmäßig so mache, dass die Defaults auch unten mit stehen. Die Erklärung ist so einfach wie banal: Ich habe die Klassenvervollständigung erst relativ spät überhaupt "entdeckt". Vorher habe ich die Routinen immer erst im interface-Teil definiert (mit Defaults) und dann einfach per Copy & Paste nach unten gebracht. So landeten die Defaults gleichermaßen in beiden Abschnitten.

Bzgl. dem "A" vor Parameternamen: Nehmen wir mal beispielsweise einen Klickhandler:
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
da heißt es ja auch nicht "ASender". Ein Blick in System.Classes.pas zeigt, dass das "A" in Eventhandler-Deklarationen tatsächlich eher die Ausnahme als die Regel ist, in Klassenmethoden und normalen Procedures dagegen genau umgekehrt. Das ändert aber nichts daran, dass man sich beim Codedesign an ein paar Gepflogenheiten halten sollte, auch wenn es technisch keine Notwendigkeit dazu gibt:
  • Pointer mit einem "P" beginnen
  • lokale Variablen mit einem "L"
  • Klassen mit einem "T"
  • Methodenparameter eben mit einem "A"
  • Interfaces mit einen "I"
  • Event-Properties mit einem "On"

Hab ich noch was vergessen? Ergänzungen wären willkommen :-)

Uwe Raabe 12. Jul 2016 08:31

AW: Vordefinierte Parameter nur im Interface-Abschnitt?
 
Zitat:

Zitat von Codehunter (Beitrag 1342401)
Hab ich noch was vergessen? Ergänzungen wären willkommen :-)

  • Felder in Klassen mit "F"
  • Attribute ohne Prefix aber mit Postfix "Attribute"

Bei den Events gibt es auch noch ein breiteres Spektrum als lediglich das "On". Man denke nur an die Before- und After-Events bei DataSets.

Das "T" wird eigentlich auch für andere Typen verwendet, die nicht zwingend Klassen sein müssen.

Wie bei allen Regeln gibt es aber auch Ausnahmen. So würde ich einem

Delphi-Quellcode:
GermanAnsiString = type AnsiString(1252);
definitiv kein T voranstellen, um die Konsistenz mit anderen Typen dieser Art (z.B. UTF8String) zu erhalten.

Codehunter 12. Jul 2016 11:56

AW: Vordefinierte Parameter nur im Interface-Abschnitt?
 
Zitat:

Zitat von Uwe Raabe (Beitrag 1342413)
Wie bei allen Regeln gibt es aber auch Ausnahmen.

Das ist klar, habe nie was anderes behauptet ^^
Zitat:

Zitat von Uwe Raabe (Beitrag 1342413)
Delphi-Quellcode:
GermanAnsiString = type AnsiString(1252);

Hihi damit ziehst du mich jetzt noch ne Weile auf, was? :lol: (Nein ich habe das Wawi noch nicht in die Tonne getreten. NOCH nicht...)


Alle Zeitangaben in WEZ +1. Es ist jetzt 07:34 Uhr.
Seite 2 von 2     12   

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