AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi resourcestring nicht in Klassen oder Records erlaubt?
Thema durchsuchen
Ansicht
Themen-Optionen

resourcestring nicht in Klassen oder Records erlaubt?

Ein Thema von Der schöne Günther · begonnen am 24. Sep 2014 · letzter Beitrag vom 25. Sep 2014
Antwort Antwort
Der schöne Günther

Registriert seit: 6. Mär 2013
6.181 Beiträge
 
Delphi 10 Seattle Enterprise
 
#1

resourcestring nicht in Klassen oder Records erlaubt?

  Alt 24. Sep 2014, 21:33
Delphi-Version: XE5
Bin ich dumm oder geht folgendes schlichtweg nicht?
Delphi-Quellcode:
TMyClass = class
   protected resourcestring
      myConst = 'Hallo Welt';
end;
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.686 Beiträge
 
Delphi 2007 Enterprise
 
#2

AW: resourcestring nicht in Klassen oder Records erlaubt?

  Alt 25. Sep 2014, 03:11
Wenn mich nicht alles täuscht, werden resourcestrings eben genau als solches einkompiliert: Als resource. Diese haben prinzipbedingt erstmal keine Zugehörigkeit zum OOP Konzept, und werden darin sehr wahrscheinlich auch nicht unterstützt.

Ich wäre nichtmals auf die Idee gekommen überhaupt Konstanten in einem Klassenkontext zu verwenden. Geht das überhaupt mit "normalen" Konstanten? Wenn ja: Wo würde man so etwas sinnvoll einsetzen? Im Scope eines Namespace (bzw. einer Unit) okay, aber als Teil einer Klasse? Vor allem: Wenn, dann müsste es ja als Klassen-Konstante implementiert sein, sonst könnte ja jede Instanz seine eigene haben, was wiederum dem Begriff "Konstante einer Klasse" entgegen stünde. Vor allem, wo würde man diese dann definieren? Zuweisen geht ja nicht (puristisch gesehen, technisch vermutlich schon). Ich zumindest bin noch keiner Situation begegnet, wo ich das Bedürfnis nach solch einem Konstrukt gehabt hätte, bin aber offen für Ideen
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.034 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#3

AW: resourcestring nicht in Klassen oder Records erlaubt?

  Alt 25. Sep 2014, 08:02
Ich wäre nichtmals auf die Idee gekommen überhaupt Konstanten in einem Klassenkontext zu verwenden. Geht das überhaupt mit "normalen" Konstanten? Wenn ja: Wo würde man so etwas sinnvoll einsetzen? Im Scope eines Namespace (bzw. einer Unit) okay, aber als Teil einer Klasse? Vor allem: Wenn, dann müsste es ja als Klassen-Konstante implementiert sein, sonst könnte ja jede Instanz seine eigene haben, was wiederum dem Begriff "Konstante einer Klasse" entgegen stünde. Vor allem, wo würde man diese dann definieren? Zuweisen geht ja nicht (puristisch gesehen, technisch vermutlich schon). Ich zumindest bin noch keiner Situation begegnet, wo ich das Bedürfnis nach solch einem Konstrukt gehabt hätte, bin aber offen für Ideen
Bei einer Konstante in einer Klasse/Record bezieht sich das einzig auf den Scope sonst nix. Wenn du innerhalb einer Klasse einen bestimmten konstanten Wert mehrfach benötigst und nicht mit magic numbers in deinem Code rumschmeißen und die Möglichkeit haben möchtest diesen Wert an einer Stelle zu ändern, bietet sich eine const in dieser Klasse durchaus an. Klar, kannste die auch ganz oldschool in den Implementation Teil deiner Unit packen, aber dann hat sie nicht genau den Scope, den du eigentlich bezweckst.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.214 Beiträge
 
Delphi 12 Athens
 
#4

AW: resourcestring nicht in Klassen oder Records erlaubt?

  Alt 25. Sep 2014, 08:54
Das ist wie bei Sub-Typen.

So hat man Typen, Konstanten, Propert/Variablen alle logisch zusammen und kann sie über die Codevervollständigung auch schön suchen lassen.
z.B. keine doppelten Prefixe und genau das finden, was man will ... z.B. siehe die neuen TColorRec-Werte (OK, per Record Helper wären sie wirklich genau da wo sie hingehören).
$2B or not $2B
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.686 Beiträge
 
Delphi 2007 Enterprise
 
#5

AW: resourcestring nicht in Klassen oder Records erlaubt?

  Alt 25. Sep 2014, 10:00
Hmm, ich verstehe die Argumente durchaus. Dennoch mutet mir das konzeptionell komisch an. Vielleicht auch, weil ich doch fast immer durchhalte eine Klasse pro Unit zu machen, und die Konstanten dann später bei potenziellen Konflikten via Namespace qualifiziere, was am Ende ja relativ ähnlich raus kommt. Aber ich verstehe durchaus die grundlegende Motivation - okay!
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Elvis

Registriert seit: 25. Nov 2005
Ort: München
1.909 Beiträge
 
Delphi 2010 Professional
 
#6

AW: resourcestring nicht in Klassen oder Records erlaubt?

  Alt 25. Sep 2014, 10:56
Solche Dinge sind ja öfter Implementierungsdetails als gewollt öffentlich sichtbare Informationen.
Und als Implementierungsdetails haben sie auch nix im öffentlichen Interfaces des Codes zu suchen.
Günthers Bleistift ziegt hier schön, dass man es so auch in Nachfahren der Klassen nutzen könnte.

Mit den aktuellen Einschränkungen muss er es wohl als resource string im "implementation"-Teil deklarieren und per protected static class function an Nachfahren weiterreichen.
Tut nicht weh, aber ich hätte gedacht, dass man mittlerweile ohne globale Dinger in Delphi auskommen kann...
Robert Giesecke
I’m a great believer in “Occam’s Razor,” the principle which says:
“If you say something complicated, I’ll slit your throat.”
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.214 Beiträge
 
Delphi 12 Athens
 
#7

AW: resourcestring nicht in Klassen oder Records erlaubt?

  Alt 25. Sep 2014, 12:13
Vielleicht auch, weil ich doch fast immer durchhalte eine Klasse pro Unit zu machen,
Das mach ich im Prinzip auch.

Aber wenn ich z.B. interne Klassen benötige, oder 'ne SubKlasse für eine Property-Gruppe, dann lege ich

Interne Klassen kann man ja theoretisch auch im Implementations-Teil deklarieren, aber nur, wenn man den Typ nicht schon für eine Referenz in der oberen Klassendeklaration benötigt.


Internes dann als private/protected und Untergeordnetes als public.
Inzwischen kommt auch noch eine Region um diese Sachen drumrum, so stören diese Dinge und die privaten/protected Methoden, sowie die Felder nicht mehr den Lesefluß, was recht praktisch ist, wenn man den Code gleich mit als Dokumentation verwendet, da so der Blick erstmal nur auf die öffentlichen Methoden/Property fallen kann.
$2B or not $2B
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:04 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 by Thomas Breitkreuz