![]() |
Delphi-Version: XE2
Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Hallo-
Übersehe ich etwas? Viele meiner Objekte haben Dinge, die einmal im Konstruktor festgelegt werden und sich danach nicht mehr ändern sollen und rein logisch auch nicht können. Konkretes Beispiel:
Delphi-Quellcode:
- Das Haus soll eine Konstante auf Instanzebene haben die im Konstruktor initialisiert wird.
THaus.Create(hausNummer:UInt16)
Natürlich kann ich es einfach später nicht mehr ändern - Aber da kriege ich Schlafstörungen. Dann gibt es noch den Compilerschalter J+ mit dem ich grundsätzlich Konstanten überall neu beschreiben kann, aber das ist doch Wahnsinn. Was tun? (Wahrscheinlich ist das wieder eine der Fragen die alle paar Monate hier auftauchen, aber ich finde nichts...) |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Wieso Konstante?
Für mich sieht das nach einer Read-Only-Property aus :gruebel: BTW: alles steht ja irgendwie, irgendwo im Speicher ... als flüchtig und beschreibbar, somit kann alles auf die eine oder andere Art auch überschrieben werden ... einen Schutz gibt es nicht ... gut wenn du dir einen WORM-RAM-Speicher dafür einbaust :mrgreen: |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
In .NET gibts dafür Readonly-Member.
In Delphi könnte das doch über ein (strict) private field in einer Basisklasse gehen, für das es einen protected Property-Accessor (nur read, kein write) gibt. In jeder Ableitung kannst Du dann nur noch lesend über das Property zugreifen, und es nicht mehr ändern. |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Danke für die Antworten.
Nur mit Properties unterbinde ich nicht, dass jemand hingeht und in anderen Instanzmethoden (versehentlich) das eigentliche Feld umbriegt, da hilft auch ein
Delphi-Quellcode:
nicht gegen.
strict private
|
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
hi,
vielleicht versteh ich das Problem nicht, aber wie soll hier jemand in einer abgeleiteten Klasse auf das Private Feld zugreifen:
Delphi-Quellcode:
oder auch umbiegen? Einzig das Property kann man öffentlich machen, ändert aber nichts am Zugriffsschutz (readOnly). In wie weit über die neue RTTI hier auf private Felder zugegriffen werden kann weiß ich allerdings nicht.
TTestBasis = class(TObject)
strict private FTestfeld: Integer; strict protected property TestFeld: Integer read FTestfeld; public constructor create(ATest: INteger); end; |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
Ist das schon zu paranoid? Ich fand es in bsp. Java oder C++ eigentlich immer ganz schön, einmal eine Konstante im Konstruktor setzen zu können und mir dann sicher zu sein dass danach nie wieder jemand dran rütteln kann... |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
Ich kenne Java/c++ nicht so genau - aber auch wenn du das dort als Konstante definiert hast: was hindert jemand das zu ändern, wenn er deinen kompletten Source hat? Grüße |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Das wäre ja schon reine Zerstörungswut :lol:
Mir ging es eher darum, dass jemand nicht aus Versehen später etwas ändert, was sich rein logisch nicht ändern kann. Wie beispielsweise die Adresse auf die ein Gerät antworten soll. |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
|
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
Ich finde auch, man sollte nur hinreichend intelligente Programmierer an die Sourcen lassen. |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Delphi-Programmierer leben wohl gerne gefährlich, was? :-D
|
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
|
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
[nicht so ganz ernst gemeint aber es sollte funktionieren]
Man könnte noch ein privates Flag mit führen: ConstIsNil:=True; Wird die "Konstante" über einen Setter definiert, wird das Flag auf False gesetzt. Weitere Zuweisungen über den Setter führen zu einem BlueScreen. Damit dürfte das Überschreiben der Konstante vermieden werden (außer jemand umgeht bewußt die Kindersicherung). [/nicht so ganz ernst gemeint aber es sollte funktionieren] |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
Bääh, nee, bitte nicht. Das halte ich ja mal für wirklich dreckig. Dann lieber sauber kommentieren. Edit: Ja, ich hab gesehen, dass du das nicht ganz ernst meinst, aber Neulinge klauen sich ja leider immer die blödsten (nicht böse gemeint) Ideen :) |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
|
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
Gruß K-H |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
Wenn du es wirklich absichern willst, setze den Wert im Konstruktor und schreibe dazu eine Prüfsumme des Wertes in ein weiteres privates Feld. Wenn dann jemand beides ändert, ist er selbst schuld. Aber eine versehentliche Änderung könntest du so später erkennen. |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
'strict private' bedeutet doch, das die Variable nur innerhalb der Unit, in der sie deklariert ist, für abgeleitete Klassen sichtbar ist.
Den Quelltext gibst Du einfach nicht weiter, dann hat sich die Sache erledigt. Dein Problem ist ja ein generelles Problem, welches so gar nicht lösbar ist. Oder hab ich mal wieder irgendwas verpasst? |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
Delphi-Quellcode:
nur die direkte Klasse kann darauf zugreifen. Weder innerhalb der Unit noch Ableitungen können darauf zugreifen
strict private
|
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
[edit] *Boah eyh*, roter Kasten wieder kaputt (schon das 2. Mal heute) [/edit] |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Diese beiden (Beispiel-) Units sollten veranschaulichen, was geht, und was nicht
Delphi-Quellcode:
unit BaseClass;
interface type TBaseClass0 = class strict private FStrictPrivate : Integer; private FPrivate : Integer; strict protected FStrictProtected : Integer; protected FProtected : Integer; public FPublic : Integer; procedure DoSomeThing; virtual; end; TBaseClass1 = class( TBaseClass0 ) public procedure DoSomeThing; override; end; procedure DoSomeThing( ABase : TBaseClass0 ); implementation { TBaseClass0 } procedure TBaseClass0.DoSomeThing; begin FStrictPrivate := 0; FPrivate := 0; FStrictProtected := 0; FProtected := 0; FPublic := 0; end; { TBaseClass1 } procedure TBaseClass1.DoSomeThing; begin inherited; // FStrictPrivate := 1; // nicht möglich FPrivate := 1; FStrictProtected := 1; FProtected := 1; FPublic := 1; end; procedure DoSomeThing( ABase : TBaseClass0 ); begin with ABase do begin // FStrictPrivate := 3; // nicht möglich FPrivate := 3; // FStrictProtected := 3; // nicht möglich FProtected := 3; FPublic := 3; end; end; end.
Delphi-Quellcode:
unit BaseClass2;
interface uses BaseClass; type TBaseClass2 = class( TBaseClass0 ) public procedure DoSomeThing; override; end; procedure DoSomeThing( ABase : TBaseClass0 ); implementation { TBaseClass2 } procedure TBaseClass2.DoSomeThing; begin inherited; // FStrictPrivate := 2; // nicht möglich // FPrivate := 2; // nicht möglich FStrictProtected := 2; FProtected := 2; FPublic := 2; end; procedure DoSomeThing( ABase : TBaseClass0 ); begin with ABase do begin // FStrictPrivate := 4; // nicht möglich // FPrivate := 4; // nicht möglich // FStrictProtected := 4; // nicht möglich // FProtected := 4; // nicht möglich FPublic := 4; end; end; end. |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
Zitat:
Ich sag ab jetzt nie wieder was. :oops: |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
Zitat:
mir war grad so, sorry... 8-) |
AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
hmmm. hmmm..mhmmmhmm...hmmhmfgfds:roll:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 14:22 Uhr. |
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