Hallo,
Also ich brauche die Properties. Da ich Mensch bin, habe ich hiermit deine Aussage wiederlegt.
Sie haben keinen Mehrwert
Oh doch, haben sie. Ein kleines Beispiel:
Delphi-Quellcode:
type
TTest= class
strict private
fMyValue: Boolean;
procedure SetMyValue(const aMyValue: Boolean);
public
property MyValue: Boolean read fMyValue write SetMyValue;
end;
var
Test: TTest;
Der lesende Zugriff auf
Test.MyValue
ist wesentlich performanter und ressourcenschonender als ein
Test.GetMyValue
, weil der Compiler durch das Feld im read aus dem
Test.MyValue
dabei ein schlankes
Test.fMyValue
macht.
und eigentlich nur Nachteile.
Ja es gibt Nachteile. Aber nur weil der Compiler zu dumm ist. Wie oben gezeigt haben die schon Vorteile. Auch das Geter und Seter sinnvoll zusammengefast sind, ist schon ein gewaltiger Vorteil.
property TmpTmp: Boolean read Schöne write Schlecht;
Denn wer bringt dem Compiler bei, dass deine GetXXX / SetXXX immer mit Get / Set anfangen müssen und XXX bei beiden gleich sein muss? Und vor allem wie?
Auch und dann der Objektinspektor, den es ohne Properties bestimmt nicht geben würde.
Die Code-Vervollständigung gibt dir keine Auskunft ob eine Property nur les-, nur schreibbar oder beides ist.
Aber nur weil die zu dumm ist. Der Compiler hat ja auch die Info. Warten wir mal den Umbau der darunter liegenden Technologie ab.
Du kannst Properties nicht als var
- oder out
-Parameter übergeben.
Ja nur weil der Compiler wiedermal zu dumm ist.
Außer du tippst gerne viel um nicht aus der Übung zu kommen.
Delphi-Quellcode:
var vTmp: Boolean;
begin
vTmp:= Test.GetMyValue;
DoTest(vTmp);
Test.SetMyValue(vTmp);
Wieso soll ich nochmal so viel Unnützes tippen? Da stelle ich doch lieber mal eine Frage zur Anregung. Wieso kann der Compiler aus dem gut lesbaren
DoTest(Test.MyValue)
nicht selbstständig ein schönes
Delphi-Quellcode:
var Dummy= Test.fMyValue;
DoTest(Dummy);
Test.SetMyValue(Dummy);
machen?
Und schöne wäre bei Parametern auch ein
property var
,
property const
,
property out
und
property in
. Dann soll ebbend eine Referenz aufs Property rein gegeben werden und nicht nur der Wert rein/raus.
Das sieht man z.B. auch daran dass Sprachen wie Java keine Entsprechung zu Delphi-Properties haben da man wohl gemerkt hat dass man mit einer einfachen Variable oder getXXX() und setXXX()-Methoden besser fährt.
Ach was interessiert mich diese eine Sprache. Die hat viel zu viele Nachteile.
Mit freundlichen Grüßen, einbeliebigername.