Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   GUI-Design mit VCL / FireMonkey / Common Controls (https://www.delphipraxis.net/18-gui-design-mit-vcl-firemonkey-common-controls/)
-   -   TStringList freigeben? (https://www.delphipraxis.net/156971-tstringlist-freigeben.html)

Mysterio08 22. Dez 2010 16:45

TStringList freigeben?
 
Hallo,

ich habe eine Funktion erstellt, bei der eine TStringList den Rückgabewert definiert. Auf der Suche danach, wie ich diese TStringList freigebe, habe ich in einem Buch gesehen, dass man das weglassen kann. Aber ist das auch wirklich guter Programmierstil?
Wenn nicht: Wie muss ich dann Result freigeben, damit nicht eine leere TStringList zurückgegeben wird?

mfg.

Deep-Sea 22. Dez 2010 17:00

AW: TStringList freigeben?
 
Wie jetzt? Ist der Rückgabeparameter vom Typ TStringList oder verwendest du eine TStringList nur intern um einen Rückgabewert (String?) zu erstellen?

Edit:
Mal ein paar Vorlagen für die verschiedenen Fälle.

Hier, wenn eine Stringliste gefüllt werden soll. TStrings anstatt TStringList zu nehmen ist hier wohl besser bzw. allgemeiner.
Man muss sich um die Erzeugung oder Freigabe innerhalb der Funktion nicht kümmern, dafür aber außerhalb.
Delphi-Quellcode:
procedure ABC(AList: TStrings);
begin
  // Tue etwas mit AList
end;

Wenn sie nur intern benötigt wird.
Delphi-Quellcode:
function ABC: String;
var
  LList: TStringList;
begin
  LList := TStringList.Create;
  try
    // Tue etwas mit LList
    Result := LList.Text; // Wenn gewünscht
  finally
    LList.Free;
  end;
end;

Wenn sie von der Funktion erstellt und als Rückgabewert benutzt wird.
Dies ist aber glaube ich nicht so gerne gesehen. Man muss sich nach dem Aufruf dieser Funktion nämlich um die Freigabe der Stringliste kümmern.
Delphi-Quellcode:
function ABC: TStringList;
begin
  Result := TStringList.Create;
  try
    // Tue etwas mit Result
  except
    Result.Free;
    raise;
  end;
end;

Mysterio08 22. Dez 2010 17:33

AW: TStringList freigeben?
 
Ich meine das Prinzip des dritten von dir geposteten Codes, Deep-Sea.
"Man muss sich nach dem Aufruf dieser Funktion nämlich um die Freigabe der Stringliste kümmern." Wie genau macht man das?
Und das raise? Das ruft doch eine Exception auf, oder?

DeddyH 22. Dez 2010 17:34

AW: TStringList freigeben?
 
Sehr richtig, Funktionen, die Objekte erzeugen und zurückgeben sind nicht sonderlich elegant (dazu gibt es auch einige Threads hier). IMO ist die erste Lösung (TStrings als Parameter) wann immer möglich vorzuziehen.

[edit] Eine Freigabe des Rückgabewertes könnte so aussehen:
Delphi-Quellcode:
var l: TStrings;
begin
  l := Funktion;
  try
    MachWasMitL;
  finally
    l.Free;
  end;
end;
[/edit]

Mysterio08 22. Dez 2010 17:44

AW: TStringList freigeben?
 
Zitat:

Zitat von DeddyH (Beitrag 1070013)
IMO ist die erste Lösung (TStrings als Parameter) wann immer möglich vorzuziehen.

[edit] Eine Freigabe des Rückgabewertes könnte so aussehen:
Delphi-Quellcode:
var l: TStrings;
begin
  l := Funktion;
  try
    MachWasMitL;
  finally
    l.Free;
  end;
end;
[/edit]

Das Interessante ist doch jetzt, was hinter "Funktion" steckt, oder nicht? Denn TStrings muss ja analog wie TStringList erstellt und auch wieder freigegeben werden.

DeddyH 22. Dez 2010 17:46

AW: TStringList freigeben?
 
"Funktion" wäre dann so etwas:
Delphi-Quellcode:
function funktion: TStrings;
begin
  Result := TStringlist.Create;
  try
    Result.Add('Eins');
    Result.Add('Zwei');
  except
    FreeAndNil(Result);
    raise;
  end;
end;

Mysterio08 22. Dez 2010 17:48

AW: TStringList freigeben?
 
Aber das funktioniert doch auch mit TStringList so. Oder welchen Vorteil hat TStrings?

Deep-Sea 22. Dez 2010 18:06

AW: TStringList freigeben?
 
Zitat:

Zitat von Mysterio08 (Beitrag 1070012)
"Man muss sich nach dem Aufruf dieser Funktion nämlich um die Freigabe der Stringliste kümmern." Wie genau macht man das?
Und das raise? Das ruft doch eine Exception auf, oder?

Wie das mit dem Freigeben geht, hat DeddyH ja gepostet. Es ist eig. der zweite von mir gepostete Code, jedoch anstatt eines "TStringList.Create" wird eben die entsprechende Funktion aufgerufen.
raise alleine löst keine Exception aus, sondern wirft innerhalb eines except-Blocks nur eine bereits aufgetretene Exception erneut aus. Ohne den try-except-Block können bei der 3. Variante Speicherlecks entstehen.

Zitat:

Zitat von Mysterio08 (Beitrag 1070018)
Aber das funktioniert doch auch mit TStringList so. Oder welchen Vorteil hat TStrings?

TStrings ist der abstrakte Vorgänger von TStringList und kann/sollte nicht erzeugt werden. Aber als Parametertyp ist es trotzdem praktisch, um andere Stringlisten als TStringList als Parameter zu erlauben.

Tyrolean 22. Dez 2010 18:13

AW: TStringList freigeben?
 
Zitat:

Zitat von Mysterio08 (Beitrag 1069998)
Hallo,

ich habe eine Funktion erstellt, bei der eine TStringList den Rückgabewert definiert. Auf der Suche danach, wie ich diese TStringList freigebe, habe ich in einem Buch gesehen, dass man das weglassen kann. Aber ist das auch wirklich guter Programmierstil?
Wenn nicht: Wie muss ich dann Result freigeben, damit nicht eine leere TStringList zurückgegeben wird?

mfg.


*Wie* man eine Stringlist freigibt ist klar. Stringlist.Free. die Frage ist eher wann

Delphi-Quellcode:
var
  sl : TStringlist;
begin
  sl := Callfunction;
  // mit sl viel oder wenig tun
  sl.Free;
end;

Deep-Sea 22. Dez 2010 18:15

AW: TStringList freigeben?
 
@Tyrolean:
Try-finally nicht vergessen :wink:


Alle Zeitangaben in WEZ +1. Es ist jetzt 20:47 Uhr.
Seite 1 von 2  1 2      

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