AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Algorithmen, Datenstrukturen und Klassendesign Delphi Variablen/Objecte Applicationsweit verfügbar machen
Thema durchsuchen
Ansicht
Themen-Optionen

Variablen/Objecte Applicationsweit verfügbar machen

Ein Thema von Hobbycoder · begonnen am 24. Apr 2017 · letzter Beitrag vom 25. Apr 2017
Antwort Antwort
Seite 1 von 2  1 2      
Hobbycoder

Registriert seit: 22. Feb 2017
961 Beiträge
 
#1

Variablen/Objecte Applicationsweit verfügbar machen

  Alt 24. Apr 2017, 19:47
Hi,

wenn ich z.B. eine ObjectList in der Main erzeuge, auf diese aber auch von weiteren Formen zugreifen will (z.B. zum Füllen einer Combobox), dann muss ich die immer an/durch alles Units durchreichen.
Zur Zeit mache ich das so:
UnitMain:
Delphi-Quellcode:
private
  TestListe: TTestListe;

Procedure Create;
  TestListe:=TTestListe.create;

procedure Destroy;
  TestListe.Free;
Unit A:
Delphi-Quellcode:
public
  TestListe: TTestListe;
und irgendwo im Code setzte ich dann UnitA.Testliste=Main.Testliste.

Sieht jetzt beschissen aus, aber ihr wisst was ich meine. Wenn ich jetzt in UnitA irgendwas mit der TestListe mache, ist das halt die aus der MainUnit.

Wie kann ich das besser machen, so dass die TestListe auf der Mainunit in allen anderen Units zur Verfügung steht, ohne dass ich sie hier so durchreiche und ohne dass ich in UnitA die UnitMain in die Uses aufnehmen müsste (will ich nämlich nicht).
Gruß Hobbycoder
Alle sagten: "Das geht nicht.". Dann kam einer, der wusste das nicht, und hat's einfach gemacht.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#2

AW: Variablen/Objecte Applicationsweit verfügbar machen

  Alt 24. Apr 2017, 19:54
Ich weiß ja nicht, ob ich Dein Anliegen richtig verstanden habe, aber Du könntest diese Liste ja in einer eigenen Unit erzeugen und wieder freigeben. Allerdings müsstest Du dann wiederum diese Unit statt der MainUnit einbinden.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: Variablen/Objecte Applicationsweit verfügbar machen

  Alt 24. Apr 2017, 19:59
Hallo,
mit so einer GlobalsUnit muss aber nichts "durchgereicht werden",
sondern immer nur diese eine Unit.
Heiko
  Mit Zitat antworten Zitat
Hobbycoder

Registriert seit: 22. Feb 2017
961 Beiträge
 
#4

AW: Variablen/Objecte Applicationsweit verfügbar machen

  Alt 24. Apr 2017, 19:59
Etwas so:
Delphi-Quellcode:
unit Unit1;

interface

uses System.Classes, System.Generics.Collections;

type
  TTestObject=class
  private
    Fblabla: string;
    procedure Setblabla(const Value: string);
  published
    property blabla: string read Fblabla write Setblabla;
  end;

  TTestList=class(TObjectList<TTestObject>);

var
  TestListe: TTestList;

implementation

{ TTestObject }

procedure TTestObject.Setblabla(const Value: string);
begin
  Fblabla := Value;
end;

initialization
  TestListe:=TTestList.Create(True);

finalization
  TestListe.Free;

end.
Und das reicht?
Gruß Hobbycoder
Alle sagten: "Das geht nicht.". Dann kam einer, der wusste das nicht, und hat's einfach gemacht.
  Mit Zitat antworten Zitat
Hobbycoder

Registriert seit: 22. Feb 2017
961 Beiträge
 
#5

AW: Variablen/Objecte Applicationsweit verfügbar machen

  Alt 24. Apr 2017, 23:26
Hab's grad mal ausprobiert. So wie oben hat es soweit gut funktioniert.

Rein theoretisch könnte ich dann diese Unit auch in einen thread aufnehmen und auch von dort auf das object zugreifen. Müsste dieser Zugriff ebenfalls über synchronize abgesichert werden? oder reichte es, dass der Zugriff mittels Getter/Setter in der Unit geregelt ist?
Gruß Hobbycoder
Alle sagten: "Das geht nicht.". Dann kam einer, der wusste das nicht, und hat's einfach gemacht.
  Mit Zitat antworten Zitat
a.def
(Gast)

n/a Beiträge
 
#6

AW: Variablen/Objecte Applicationsweit verfügbar machen

  Alt 24. Apr 2017, 23:29
Zitat:
Variablen/Objecte Applicationsweit verfügbar machen
Ich benutze dafür immer Record-Typen wo alle Variablen, Objekte usw drin sind.
Keine Setter, keine Getter, nix. Einfach nur ein Record.
  Mit Zitat antworten Zitat
Hobbycoder

Registriert seit: 22. Feb 2017
961 Beiträge
 
#7

AW: Variablen/Objecte Applicationsweit verfügbar machen

  Alt 24. Apr 2017, 23:33
Records würden natürlich auch gehen. Obiger code ist ja nur ein Beispiel.
Das Object im aktuellen Projekt existiert bereits und enthält noch einige Listen, etc. Von daher werde ich das so lassen.
Keine Setter, keine Getter, nix. Einfach nur ein Record.
Das beantwortet aber meine Frage nicht.
Gruß Hobbycoder
Alle sagten: "Das geht nicht.". Dann kam einer, der wusste das nicht, und hat's einfach gemacht.
  Mit Zitat antworten Zitat
Aviator

Registriert seit: 3. Jun 2010
1.611 Beiträge
 
Delphi 10.3 Rio
 
#8

AW: Variablen/Objecte Applicationsweit verfügbar machen

  Alt 25. Apr 2017, 00:28
Entweder Getter und Setter (mit Delphi-Referenz durchsuchenTCriticalSection) oder den Delphi-Referenz durchsuchenTMultiReadExclusiveWriteSynchronizer (nie selbst benutzt) oder beim Schreiben mit Synchronize absichern. Das sollte es eigentlich gewesen sein. Mir gefällt da die CriticalSection Variante am Besten. Zumindest ist sie relativ einfach umzusetzen.

Es gibt da soweit ich weiß auch noch TMonitor. Habe ich aber auch noch nie benutzt und kann daher auch nicht sagen wie gut/schlecht das funktioniert.
  Mit Zitat antworten Zitat
a.def
(Gast)

n/a Beiträge
 
#9

AW: Variablen/Objecte Applicationsweit verfügbar machen

  Alt 25. Apr 2017, 00:42
Bei sehr vielen Zugriffen in sehr kurzer Zeit ist TMonitor deutlich langsamer als CriticalSections.
Musste ich damals leider herausfinden, nachdem ich alles auf TMonitor umgebaut hatte.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Variablen/Objecte Applicationsweit verfügbar machen

  Alt 25. Apr 2017, 10:42
Durchreichen hat aber den Vorteil, dass alle Programmmodule unabhängig, wiederverwenbar und einzeln Testbar/austauschbar sind,
wenn die keine Verbindung zur TForm1 haben.

Klar, manche kommen jetzt vielleicht auch auf die Idee überall Unit1 einzubinden und dann über Form1.TestListe drauf zuzugreifen (die Variable oder ein Property in Public),
anstatt diese Variable in eine gemeinsame Unit auszulagern und sie überall einzubinden.


Mal ein Beispiel für
* Klassen-Methoden/Property statt globalen Variablen
* Klassen-Konstructororen statt Initialization

Die Delphi-Programme würden schneller starten und, bräuchten weniger RAM und hätten kleinere EXEn, wenn die RTL/VCL/FMX nicht ständig alles in Initialiazation machen würden, was dann eh fast niemand braucht, aber durch das Initialization ständig mit eingebunden wird.

Kann man auch in einen Record oder die TTestList-Klasse einfügen.

Delphi-Quellcode:
type
  TTestObject = class
  private
    Fblabla: string;
    procedure Setblabla(const Value: string);
  published
    property blabla: string read Fblabla write Setblabla;

  private class var
    FTestListe: TObjectList<TTestObject>;
  private
    class function GetTestListe: TObjectList<TTestObject>; static;
  public
    //class constructor Create; // statt des initialization, aber wird nur aufgerufen, wenn die Klasse TTestObject auch im Programm verwendet wird
    //property TestListe: TObjectList<TTestObject> read FTestListe;
    class property TestListe: TObjectList<TTestObject> read GetTestListe; // erst erzeugen, wenn auch wirklich gebraucht wird (alternativ eben schon im class constructor)
    class destructor Destroy; // statt des finalization, aber wird nur aufgerufen, wenn die Klasse TTestObject auch im Programm verwendet wurde
  end;

implementation

{ TTestObject }

procedure TTestObject.Setblabla(const Value: string);
begin
  Fblabla := Value;
end;

class function TTestObject.GetTestListe: TObjectList<TTestObject>;
begin
  if not Assigned(FTestListe) then
    FTestListe := TTestList.Create(True);
  Result := FTestListe;
end;

class destructor TTestObject.Destroy;
begin
  FreeAndNil(TestListe); // bei globalen Variablen besser immer FreeAndNil, statt Free ... dann knallt es schöner, wenn jemand nach Freigabe nochmal grauf zugreift
end;

Und zum Thema Synchronisation, falls aus mehreren Threads zugegriffen wird, wurde schon viel geschrieben,
aber ich erwähne auch mal die TThreadList.
$2B or not $2B

Geändert von himitsu (25. Apr 2017 um 11:27 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 09:32 Uhr.
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