![]() |
Eine Variable für alle Units zugänglich machen?
Wie kann ich am einfachsten eine Variable (string) mit einem Text versehen, und die dann für alle Units zugänglich zu haben. Dabei sollte es vor dem Createprozedur geschehen.
Nun kann ichs auch nicht im Create machen, weil die anderen Formulare auch diese Variable benötigen. Und eigentlich ist es ja unsinnig mehrere Variablen und mehrere sets der Variablen durchzuführen... Deshalb muss das irgendwie (wahrscheinlich) in der Projektdatei stehen... nur wie mache ich da Variablen "public"? PS: Möglichst einfach :P |
Re: Eine Variable für alle Units zugänglich machen?
Wie wärs mit dem initialization-Abschnitt?
|
Re: Eine Variable für alle Units zugänglich machen?
Wovon?
Der Projektdatei? Sind die Variablen dann auch für die Units zugänglich? |
Re: Eine Variable für alle Units zugänglich machen?
Nein. Der initialization-Abschnitt einer Unit deiner Wahl. Alle Units, die diese Unit einbinden, können auf die Variable zugreifen. Eine Projektdatei hat keine Initialization und soweit ich weiß kann eine Unit auch nicht auf Variablen der Projektdatei zugreifen.
|
Re: Eine Variable für alle Units zugänglich machen?
Zitat:
Es gibt eine Unit, die dient als Schnittstelle für globale Daten der Anwendung und auch von PlugIns. Sie besitzt ein Objekt "Host", wo Variablen, bestimmte Methoden, Datenbanktabellen etc. vorhanden sind. In dieser Unit gibt es auch schon eine Variable für das Objekt, sie steht direkt darunter (also ähnlich wie bei den TForms). Nun kann ich dieses Objekt in z.B. der ersten Unit erstellen lassen, die während des Projekt-Starts erzeugt wird. ich kann dann von allen Units auf dieses globale Objekt und auf dessen Variablen / Methoden etc. zugreifen. Normal sind ja globale Variablen in der OOP verpöhnt, aber nicht aus Prinzip, sondern eher dann, wenn man's übertreibt und nicht mehr durchblick... Gruß Pfoto |
Re: Eine Variable für alle Units zugänglich machen?
Zitat:
@xZise: Auf Unit-Globale Variablen würde ich verzichten, ist ganz schlechter Stil und wirklich unschön. Gruss Thorsten |
Re: Eine Variable für alle Units zugänglich machen?
@Pfoto: Würdest du da mit dem Singleton-Pattern nicht besser fahren? Gleiche (globale-Variablen-freie :)) Empfehlung an xZise ;) .
|
Re: Eine Variable für alle Units zugänglich machen?
*Finger zum Kreuz erhebe* Geh weg mit deiner .Net-Versuchung, Khabarakh! Zumindest wüsste ich nicht, wos in D.W32 ein Singleton-Pattern gibt...
|
Re: Eine Variable für alle Units zugänglich machen?
Zitat:
Obwohl ich davon weiß, ist es mir leider noch nicht so präsent, dass ich es bereits wie selbstverständlich einbaue... Aber welchen echten praktischen Vorteil hätte es wenn ich davon ausgehen könnte, das während des Programmablaufs *nicht* unbeabsichtigt mehrere Instanzen erstellt werden? Ist es dann wirklich nur eine Sache aus Prinzip? Gruß Pfoto |
Re: Eine Variable für alle Units zugänglich machen?
@DGL-Luke: Ein Singleton Pattern ist nichts .NET-Spezifisches. Man kann es auch in Delphi implementieren, auch wenn ich finde, das gehört eher in die GC Sprachen wie Java, C# und PHP.
|
Re: Eine Variable für alle Units zugänglich machen?
Zitat:
@DGL-Luke: :cry: :gruebel:
Delphi-Quellcode:
Genausogut mit Eager Creation möglich. Dasimho einzig Unschöne ist der öffentliche Konstruktor, aber TObject.Create ist nunmal dämlicherweise public.
type
TFFA = class strict private class var FInstance: TFFA; constructor InternalCreate; class function GetInstance: TFFA; static; public class property Instance: TFFA read GetInstance; constructor Create; end; { TFFA } constructor TFFA.Create; begin raise SingletonException.Create(TFFA); end; class function TFFA.GetInstance: TFFA; begin if not Assigned(FInstance) then FInstance := TFFA.InternalCreate; Result := FInstance; end; constructor TFFA.InternalCreate; begin ... end; [add] In ähnlicher Weise natürlich auch mit Versionen < 2006 möglich. [/add] [add id="1"] @3/8: :gruebel: Für das Singleton-Pattern wird man in jeder Sprache eine globale Variable bzw. ein statisches Feld benötigen und solche sind in den allermeisten Sprachen Garbage-Collection-Roots, also nicht wegfegbar bis zur Terminierung. [/add] |
Re: Eine Variable für alle Units zugänglich machen?
:lol: Frag mich nicht, wie ich auf GC gekommen bin. Eigentlich meinte ich Sprachen mit einer Klassenstruktur, die das Verstecken eines Konstruktors erlauben.
|
Re: Eine Variable für alle Units zugänglich machen?
Achso, ok :lol: .
Hätt ich an deiner Stelle jetzt auch behauptet :mrgreen: BTT: Die Sache mit dem Konstruktor würde ich nicht so eng sehen. Das Prinzip der Sichtbarkeit ist klasse, aber soll keine Idiotenabwehr sein. Wer nicht hören will, muss bei "TSingleton.Create" eben fühlen :mrgreen: . |
Re: Eine Variable für alle Units zugänglich machen?
Ähm ich habe zwar kein Plan wegen den Singleton Pattern...
Aber ich hätte es jetzt auch ungefähr so gemacht, nur das das Problem ist, dass ich die Instanz irgendwie "weitergeben" muss :D |
Re: Eine Variable für alle Units zugänglich machen?
naja... dann kannst du auch die Klasse weitergeben. Abstrakte Klasse TSingleton mit der class procedure GetInstance.
@Khabarakh: Bist du dir sicher, dass das so hinhaut? immerhin wirft der konstruktor, und der wird in getinstacne aufgerufen... |
Re: Eine Variable für alle Units zugänglich machen?
Zitat:
|
Re: Eine Variable für alle Units zugänglich machen?
@DGL-Luke: Uppsala, das nennt man fehlgeschlagenes Refactoring :stupid: . Muss natürlich ein Aufruf des privaten Konstruktors sein.
Zitat:
|
Re: Eine Variable für alle Units zugänglich machen?
Ja, in gewisser Weise ist ja der Programmierer, der die Unit einbindet, ein User der Unit.
Wenn ich eine Unit/mehrere Units schreibe, interpretiere ich den Programmierer, der es später verwendet, als User. Und dieser User könnte ja ein DAU sein, und der soll möglichst wenig falsch machen können. |
Re: Eine Variable für alle Units zugänglich machen?
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:33 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