Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Inhalt TStringList in andere TStringList kopieren (https://www.delphipraxis.net/136480-inhalt-tstringlist-andere-tstringlist-kopieren.html)

Antonov 25. Jun 2015 12:07

AW: Inhalt TStringList in andere TStringList kopieren
 
Das mit der Groß-Kleinschreibung muss mir nicht gefallen, aber Recht hast du schon. Ist wie in Physik mit den Einheiten oder Beschriftungen. Ohne sie versinkt man im Chaos.

Das mit Result:= TStringlist.Create ist mir ziemlich neu, ich habe noch nicht gesehen, dass man sie erst deklarieren muss. Andere Funktionen von mir kommen ohne diese Deklaration aus.
Und ich möchte den Inhalt einer Stringliste kopieren, und nicht nur einen Zeiger oder auf sie referenzieren. Lustigerweise macht man nicht
Delphi-Quellcode:
Result.Free;
am Ende, obwohl man die Liste kreeiert hat. Hm.

p.s. Das mit
Delphi-Quellcode:
Try Finally
habe ich erst seit kurzem gelernt und habe es in diesem Relikt von Programm noch nicht :P ... Betonung auf "noch"

mkinzler 25. Jun 2015 12:08

AW: Inhalt TStringList in andere TStringList kopieren
 
Zitat:

Lustigerweise macht man nicht Result.Free; am Ende, obwohl man die Liste kreeiert hat. Hm.
Du willst diese ja auch zurückgeben und nicht nur ein Nil

Popov 25. Jun 2015 12:27

AW: Inhalt TStringList in andere TStringList kopieren
 
Zitat:

Zitat von Antonov (Beitrag 1306576)
Das mit Result:= TStringlist.Create ist mir ziemlich neu...

Wieder was gelernt ;)

Wenn du nur eine 08/15 Variable zurück geben willst, wie String oder Integer, das sind keine Objekte, da musst du ja auch nicht machen. Wenn es eine String-Funktion ist, dann ist Result eben ein String. Anders sieht es aber aus wenn die Funktion ein Objekt ist. In dem Fall muss man das Objekt erst erzeugen (und den Speicher reservieren). Ohne das hast du nur eine Adresse, im Grunde ein Integer, aber keinen reservierten Speicher. Das Ergebnis ist ein Error.

Das Result.Free habe ich nicht vergessen. Das findet sich in der anderen Prozedur (siehe
Delphi-Quellcode:
slResult.Free;
). Man kann Objekte auch über mehrere Prozeduren verteilen. Nur darf man nicht vergessen es frei zu geben.

Ansonsten macht AddStrings das wofür es gedacht ist: es fügt die Liste von einer TStringList an eine andere an. Man kann es aber auch zum Kopieren "missbrauchen".

haentschman 25. Jun 2015 13:24

AW: Inhalt TStringList in andere TStringList kopieren
 
Hallöle...8-)

mal ein wenig Lesestoff zum Thema: Objektinstanzen als Rückgabewert von Functionen und warum man das nicht tun sollte.
http://www.detlef-heibing.de/program...rueckgabe.html
http://forum.delphi-treff.de/index.p...-von-Funktion/

Grundsatz:
Wer erzeugt, gibt frei.
Ausnahme:
Wenn aus dem Funktionsnamen hervorgeht das ein Objekt erzeugt wird.
Delphi-Quellcode:
function CreateBlubbList: TSTringlist;
Diese Funktion macht dann auch nix anderes als das Objekt zur Verfügung zu stellen. Damit wird deutlich das ich mich selbst um die Freigabe des Objektes kümmern muß. Man darf nicht nur an sich denken sondern auch an den der die Funktion ggf. mal verwendet. 8-)

p80286 25. Jun 2015 13:32

AW: Inhalt TStringList in andere TStringList kopieren
 
Bitte lass das!
Zitat:

Zitat von haentschman (Beitrag 1306592)
Grundsatz:
Wer erzeugt, gibt frei.

Die Konsequenz hiervon ist es, die benötigte Liste als Parameter an eine Procedure zu übergeben. Aus eigener Erfahrung weiß ich, das Funktionsergebnisse manchmal anfangen ein Eigenleben zu führen.
Also nicht
Delphi-Quellcode:
Persliste:=HolePersliste;
Sondern
Delphi-Quellcode:

persliste:=TStringlist.Create;
FuellePersliste(persliste);
..
persliste.Free;
Gruß
K-H

FarAndBeyond 25. Jun 2015 13:34

AW: Inhalt TStringList in andere TStringList kopieren
 
Ich würde in Verbindung mit TStringlisten immer FreeAndNil verwenden.

FreeAndNil(stringlist_xyz);
oder
stringlist_xyz.Free;
stringlist_xyz := Nil;

Dann kann man auch ohne Probleme Assign benutzen wenn man's braucht...
Und wann immer möglich mit Nil initialisieren...


Gruß
Martin

vagtler 25. Jun 2015 13:41

AW: Inhalt TStringList in andere TStringList kopieren
 
Zitat:

Zitat von haentschman (Beitrag 1306592)
[...] Man darf nicht nur an sich denken sondern auch an den der die Funktion ggf. mal verwendet. 8-)

"Code as if the next guy to maintain your code is a homicidal maniac who knows where you live."

BUG 25. Jun 2015 13:47

AW: Inhalt TStringList in andere TStringList kopieren
 
Zitat:

Zitat von p80286 (Beitrag 1306596)
Die Konsequenz hiervon ist es, die benötigte Liste als Parameter an eine Procedure zu übergeben. Aus eigener Erfahrung weiß ich, das Funktionsergebnisse manchmal anfangen ein Eigenleben zu führen.

Ein in C++ übliches Muster ist es, die Referenz auch wieder zurückzugeben. Das macht den Datenfluss schön sichtbar.

Delphi-Quellcode:
persliste := FuellePersliste(TStringlist.Create);
..
persliste.Free;

bernau 25. Jun 2015 13:58

AW: Inhalt TStringList in andere TStringList kopieren
 
Ich sehe es so wie haenschman. Wer erzeugt gibt frei.

Allerdings gibt es auch Fälle, bei denen ich in einer Funktion ein Objekt erzeuge und dann bestimmte Parameter setzte.

Anstatt eine sortierte Stringliste herkömmlich zu erzeugen:

Delphi-Quellcode:
lStringlist:=TStringlist.create;
lStringlist.sorted:=true;
lStringlist.duplicates = dupIgnore;
mache ich mir eine Funktion

Delphi-Quellcode:
function TStringlistSortedCreate:TStringlist;
begin
  result:=TStringlist.create;
  result.sorted:=true;
  result.duplicates = dupIgnore;
end;
Verwendet wird es so:

Delphi-Quellcode:
  lStringlist:=TStringlistSortedCreate;

Wie gesagt. Nur ein Kurzes Beispiel um aus drei Zeilen eine Zeile zu machen.

Finde ich ganz angenehm.

Popov 25. Jun 2015 14:23

AW: Inhalt TStringList in andere TStringList kopieren
 
Eine Funktion die als Result ein Objekt zurück gibt ist ja schön und manchmal gibt es keine andere Möglichkeit, aber das muss man immer zu gut aufpassen, nichts zu vergessen.

Ich persönlich favorisiere diese Methode. Da wird nichts verteilt:
Delphi-Quellcode:
procedure MachWas(Bmp: TBitmap);
begin
  Bmp.Canvas.Brush.Color := clRed;
  Bmp.Width := 400;
  Bmp.Height := 200;
end;

procedure TForm1.Button1Click(Sender: TObject);
var
  Bmp: TBitmap;
begin
  Bmp := TBitmap.Create;
  try
    MachWas(Bmp);
    Canvas.Draw(10, 10, Bmp);
  finally
    Bmp.Free;
  end;
end;


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

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