AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Algorithmen, Datenstrukturen und Klassendesign Constructor Rückgabewert nil-en statt Instanz zurückzugeben?
Thema durchsuchen
Ansicht
Themen-Optionen

Constructor Rückgabewert nil-en statt Instanz zurückzugeben?

Ein Thema von günni0 · begonnen am 11. Apr 2018 · letzter Beitrag vom 12. Apr 2018
Antwort Antwort
Seite 3 von 3     123   
günni0
(Gast)

n/a Beiträge
 
#21

AW: Constructor Rückgabewert nil-en statt Instanz zurückzugeben?

  Alt 11. Apr 2018, 17:18
Ich gebe mal etwas vor. Wie sähe das denn korrekt aus mit einer Factory-Class?

Delphi-Quellcode:
type
 TMyClass = class
 public
  constructor Create(Parameter);
  destructor Destroy; override;
end;

implementation

constructor TMyClass .Create(Parameter);
begin
 prüfe dies

 prüfe das

 WENN Fehler/korrupte Daten, dann raise exception und abbrechen

 SONST
  am Ende erstelle Thread -A- oder -B-
end;

destructor TMyClass .Destroy;
begin
 if Assigned(ThreadA) then
  begin
   ThreadA.Stop; // Funktion in der Thread-Unit selber - hat schon seinen Sinn :P
   ThreadA.Free;
  end;

  // ThreadB, wenn Assigned, wird an anderer Stelle von Hand freigegeben

 inherited Destroy;
end;
Delphi-Quellcode:
TMyClass: TList;


try
 myClass := TMyClass.Create(Parameter);
except
end;

if Assigned(myClass) then // wenn oben rause ausgelöst wird, ist myClass not Assigned und muss nicht hinzugefügt werden
 MyGenericTList.Add(myClass);
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.477 Beiträge
 
Delphi 12 Athens
 
#22

AW: Constructor Rückgabewert nil-en statt Instanz zurückzugeben?

  Alt 11. Apr 2018, 17:24
Warum nicht so?

Delphi-Quellcode:
try
  myClass := TMyClass.Create(Parameter);
  MyGenericTList.Add(myClass);
except
  // hier sollte schon och was passieren, oder?
end;
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

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

AW: Constructor Rückgabewert nil-en statt Instanz zurückzugeben?

  Alt 11. Apr 2018, 17:26
Da du im Konstruktor bist und als input also nur "parameter" zur Verfügung hast und nicht irgendwelchen State einer schon vorhandenen Instanz frage ich mich, warum "prüfe dies" und "prüfe das" dort drin sein muss und nicht vorgelagert, so dass eine Instanzerstellung erst dann durchgeführt werden muss, wenn auch alles i.O ist? Aber das hängt davon ab, wie häufig nun dieser Ausnahmefall auftritt.

Wenn das in der gleichen Kategorie wie "Datei beim Erstellen eines TFileStreams konnte nicht geöffnet werden" anzuordnen ist, dann ist das mMn schon in Ordnung. Ablauf dann so wie Uwe schon schrieb.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight

Geändert von Stevie (11. Apr 2018 um 17:30 Uhr)
  Mit Zitat antworten Zitat
günni0
(Gast)

n/a Beiträge
 
#24

AW: Constructor Rückgabewert nil-en statt Instanz zurückzugeben?

  Alt 11. Apr 2018, 17:40
Zitat:
Warum nicht so?

...
Werde ich gleich testen.

Zitat:
Da du im Konstruktor bist und als input also nur "parameter" zur Verfügung hast und nicht irgendwelchen State einer schon vorhandenen Instanz frage ich mich, warum "prüfe dies" und "prüfe das" dort drin sein muss und nicht vorgelagert, so dass eine Instanzerstellung erst dann durchgeführt werden muss, wenn auch alles i.O ist?
Wenn ich das alles auslagere habe ich an zwei Stellen einen Aufruf mehr. Davon geht die Welt nicht unter. Ich werde es testen.
Dann wäre ich zudem auch das try-except los.
Zum Schluss könnte ich, da ich den Aufruf zweimal habe, das alles in eine Prozedur packen. Dann muss ich nur an einer Stelle ändern, wenn es was zu ändern gibt.
Ist schluss-endlich alles viel einfacher als Factory-Konstrukte o.ä.

Edit
klappt soweit ganz gut. Code ist sauber, im Konstruktor wird nur noch den Properties-Variablen zugewiesen und alle Überprüfungen sind raus.

Geändert von günni0 (11. Apr 2018 um 18:33 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.659 Beiträge
 
Delphi 11 Alexandria
 
#25

AW: Constructor Rückgabewert nil-en statt Instanz zurückzugeben?

  Alt 12. Apr 2018, 08:21
Zur Ergänzung noch die Lösung per Factory-Methode:
Delphi-Quellcode:
TMyClass = class
public
  class function TryGetInstance(const AValue: string; out AInstance: TMyClass): Boolean;
end;

class function TMyClass.TryGetInstance(const AValue: string; out AInstance: TMyClass): Boolean;
var
  NewInstance: TMyClass;
begin
  NewInstance := TMyClass.Create;
  Result := NewInstance.Init(AValue);
  if Result then
    AInstance := NewInstance
  else
    NewInstance.Free;
end;
Vorteil ist, dass du zur Verwendung nur brauchst:
Delphi-Quellcode:
var
  MyObject: TMyClass;
begin
  if TMyClass.TryGetInstance('blub', MyObject) then
    List.Add(MyObject);

Besser wäre natürlich, wenn die Prüfung wie schon genannt wurde auch z.B. per Klassenmethode möglich wäre, dann müsste bei einem Fehler gar nicht erst eine dann nicht benötigte Instanz erstellt werden.
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
günni0
(Gast)

n/a Beiträge
 
#26

AW: Constructor Rückgabewert nil-en statt Instanz zurückzugeben?

  Alt 12. Apr 2018, 10:38
Zitat:
Besser wäre natürlich, wenn die Prüfung wie schon genannt wurde auch z.B. per Klassenmethode möglich wäre, dann müsste bei einem Fehler gar nicht erst eine dann nicht benötigte Instanz erstellt werden.
Deswegen habe ich es nach euren Vorschlägen auch so umgesetzt.

Ich habe den Code ordentlich in verschiedene Units aufgeteilt.
Erst rufe ich eine Prozedur aus der ersten Unit auf. Die überprüft alle Daten und wenn alles OK ist, ruft Prozedur 1 den Constructor in einer anderen Prozedur auf.

Genau eine Zeile brauche ich für diesen Aufruf.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 3 von 3     123   


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 22:30 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