Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Delphi Auf private Variable zugreifen (https://www.delphipraxis.net/182774-auf-private-variable-zugreifen.html)

JasonDX 18. Nov 2014 08:05

AW: Auf private Variable zugreifen
 
Ob/Wann man private verwendet hängt davon ab, welche Garantien man für dieses Feld geben und erwarten will. Wenn ich private member deklariere, dann in der Annahme, dass meine Klasse, und NUR meine Klasse diese liest und bearbeitet. Wenn ich also einen privaten String phoneNumber habe, und den in meiner Klasse nur mit einem bestimmten Format fülle, gehe ich im Rest der Klasse davon aus, dass dieser String ein bestimmtes Format hat.
Wenn nun andere Klassen diesen Wert schreiben, habe ich diese Garantie nicht mehr. Deswegen: Schreibe nie private Member von anderen Klassen. Die Klasse selbst erwartet u.U. bestimmte Konventionen, und hat ein undefiniertes Verhalten wenn diese Konventionen nicht eingehalten werden.
Das selbe geht in die andere Richtung: In einem kleinen Update ändere ich das Format dieses Strings. Das Update kann schleichend kommen - es beinhaltet keine Veränderung des APIs, und interessiert auch keinen außerhalb. Es ist schließlich das persönliche private member der Klasse. Wenn nun aber eine andere Klasse diesen Wert liest, und annimmt, dass der String ein bestimmtes Format hat, bringt diese Änderung ein undefiniertes Verhalten hervor, weil Annahmen, die für dieses Feld getroffen wurden, nicht mehr gelten.

Wenn man bspw. einen von außerhalb zugänglichen Getter setzt (sei es durch Private und Kindklassen), dann setzt man bestimmte Garantien für das Feld, die ein einfaches Ändern nicht mehr erlauben, bzw. der Getter entsprechende Umwandlung o.ä. vollzieht. Er ist aber Teil des APIs und muss damit den dokumentierten Anforderungen genügen. Ebenso andersrum: hat man einen von außerhalb zugänglichen Setter, können dafür Erwartungen definiert werden, die evt. auch im Setter überprüft werden (bspw. dass der String in einem bestimmten Format sein soll)
Der wichtigste Punkt ist: Diese Erwartungen und Garatien sind dann dokumentiert, und können(/sollten) sich nicht ohne weiteres von einen Tag auf den nächsten ohne Ankündigung ändern. Das gilt nicht für private member.

Kurzum: Private hat seine Daseinsberechtigung, und sollte auch nicht durch Tricks/Hacks umgangen werden. Es endet in einem Haufen Dung in der Codebase.

Elrond 18. Nov 2014 08:19

AW: Auf private Variable zugreifen
 
Ich weiß nicht inwiefern das jetzt passt.
Aber ich musste auch mal auf ein privat Feld zugreifen und zwar wollte ich damals von TField den TFieldType zur Laufzeit ändern ohne es in jeden Formular anzupassen. Das ganze habe ich über die RTTI realisiert, dass klappt soweit ich weiß nur bei private Feldern die nicht strict private sind.

Delphi-Quellcode:
procedure ChangeProperty(Sender: TObject);
  var
    Context                            : TRttiContext;
    RttiField                          : TRttiField;
    RttiValue                          : TValue;
  begin
    RttiField := Context.GetType(TField).GetField('FDataType');
    RttiValue := TValue.FromOrdinal(TypeInfo(TFieldType), 24); //24 ftWideString

    RttiField.SetValue(Sender, RttiValue);
  end;


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

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