Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Ich vermisse Konstanten erst im Konstruktor initialisieren zu können (https://www.delphipraxis.net/174200-ich-vermisse-konstanten-erst-im-konstruktor-initialisieren-zu-koennen.html)

Der schöne Günther 9. Apr 2013 09:49

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:
THaus.Create(hausNummer:UInt16)
- Das Haus soll eine Konstante auf Instanzebene haben die im Konstruktor initialisiert wird.


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...)

Sir Rufo 9. Apr 2013 09:53

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:

Phoenix 9. Apr 2013 09:54

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.

Der schöne Günther 9. Apr 2013 09:57

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:
strict private
nicht gegen.

Lemmy 9. Apr 2013 10:31

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:
  TTestBasis = class(TObject)
  strict private
    FTestfeld: Integer;
  strict protected
    property TestFeld: Integer read FTestfeld;
  public
    constructor create(ATest: INteger);
  end;
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.

Der schöne Günther 9. Apr 2013 10:35

AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
 
Zitat:

Zitat von Lemmy (Beitrag 1210759)
hi,

vielleicht versteh ich das Problem nicht, aber wie soll hier jemand in einer abgeleiteten Klasse [...]

Dort natürlich nicht. Aber in der selben Klasse wäre es, ganz banal durch Unwissen oder Unachtsamkeit, möglich.

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...

Lemmy 9. Apr 2013 10:41

AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
 
Zitat:

Zitat von Der schöne Günther (Beitrag 1210760)
hi,
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...

ja - finde ich paranoid :-)

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

Der schöne Günther 9. Apr 2013 10:43

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.

Sir Rufo 9. Apr 2013 10:53

AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
 
Zitat:

Zitat von Der schöne Günther (Beitrag 1210762)
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.

In der Klasse entsprechend dokumentieren (z.B. an der property) und gut ist

Uwe Raabe 9. Apr 2013 10:55

AW: Ich vermisse Konstanten erst im Konstruktor initialisieren zu können
 
Zitat:

Zitat von Sir Rufo (Beitrag 1210765)
In der Klasse entsprechend dokumentieren (z.B. an der property) und gut ist

:thumb:

Ich finde auch, man sollte nur hinreichend intelligente Programmierer an die Sourcen lassen.


Alle Zeitangaben in WEZ +1. Es ist jetzt 06:35 Uhr.
Seite 1 von 3  1 23      

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