AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Stringlist und Objects

Ein Thema von Berni68 · begonnen am 30. Aug 2009 · letzter Beitrag vom 30. Aug 2009
Antwort Antwort
Berni68

Registriert seit: 9. Jan 2006
Ort: Villingen
162 Beiträge
 
Delphi XE5 Professional
 
#1

Stringlist und Objects

  Alt 30. Aug 2009, 10:15
Hallo zusammen,

ich benötige recht häufig Stringlisten.
An den Stringlisteneinträgen hängen noch weitere Daten dran.

Das mache ich wie folgt (in Anlehnung an einen anderen Beitrag aus der DP):

Delphi-Quellcode:
type
  TDat = class(TObject)
    s: string;
    ...
    destructor Destroy; override; // nur zum testen
  end;
Delphi-Quellcode:
destructor TDat.Destroy;
begin
  showmessage('TDat.Destroy');
  inherited Destroy;
end;
Verwendet wird das so:
Delphi-Quellcode:
  dat:= TDat.Create;
  with d do begin
    s:= 'Test';
    ...
  end;
  MeineStringListe.AddObject('Zeile', dat);

Das funktioniert soweit auch.
Das Problem aber ist nun folgendes:

Mit
  MeineStringListe.Clear; und
  MeineStringListe.Free; erzeugt man Speicherleichen.
-> Wie kann ich solche Speicherleichen auffinden:
Gerade in einem anderen Beitrag gefunden: mit -> TObjectList geht das wohl
werd ich gleich mal probieren!

Man könnte zwar vor Clear oder Free

  with MeineStringListe do for i:=0 to Count-1 do Objects[i].Free; aufrufen, finde ich aber umständlich.
-> Gibt es eine elegantere Möglichkeit?

Eleganter wäre wohl:

Delphi-Quellcode:
type
  TObjStringList = class(TStringList)
    procedure Delete(Index: Integer); override;
  end;

procedure TObjStringList.Delete(Index: Integer);
begin
  Showmessage('TObjStringList.Delete '+IntToStr(Index));
  Objects[Index].Free;
  inherited;
end;
Wenn man einzelnen Stringlisteneintrag löscht geht das zwar,
aber bei Clear und Free wird delete nie aufgerufen
(-> ich dachte zumindest clear ruft für alle delete auf)
muss man dann neben delete auch clear und/oder free überschreiben
oder besser:

gibt es was fertiges im Sinne von TObjStringList bei dem schon an alles gedacht wurde?
Bernhard
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: Stringlist und Objects

  Alt 30. Aug 2009, 10:23
ich glaub bei StringList.OwnsObjects := True; gibt er diese selber frei.
$2B or not $2B
  Mit Zitat antworten Zitat
alzaimar
(Moderator)

Registriert seit: 6. Mai 2005
Ort: Berlin
4.956 Beiträge
 
Delphi 2007 Enterprise
 
#3

Re: Stringlist und Objects

  Alt 30. Aug 2009, 10:25
Zitat von Berni68:
gibt es was fertiges im Sinne von TObjStringList bei dem schon an alles gedacht wurde?
Nein, aber das selbst zu basteln sollte eine Arbeit von nicht einmal 5, na ja 10 Minuten darstellen. Ich würde so eine Komponente z.B. nicht verwenden, da in meinen Augen die Stringliste so kein geeigneter Container für eine Objektliste ist, aber das ist Geschmackssache.
"Wenn ist das Nunstruck git und Slotermeyer? Ja! Beiherhund das Oder die Flipperwaldt gersput!"
(Monty Python "Joke Warefare")
  Mit Zitat antworten Zitat
Benutzerbild von mirage228
mirage228

Registriert seit: 23. Mär 2003
Ort: Münster
3.750 Beiträge
 
Delphi 2010 Professional
 
#4

Re: Stringlist und Objects

  Alt 30. Aug 2009, 10:27
Zitat von himitsu:
ich glaub bei StringList.OwnsObjects := True; gibt er diese selber frei.
Zumindest in Delphi 7 gibt es diese Eigenschaft nicht und da er laut Profil Delphi 5 Prof verwendet, wird das wohl so nicht gehen, wobei ich mich auch nicht entsinne, dass es diese Eigenschaft bei TStringList in neueren Delphi Versionen gibt...

Musst Du wohl doch selbst bauen, wobei da die 3 Methode Delete, Clear und Free anzupassen kein großer Aufwand sein sollten

Viele Grüße
David F.

May the source be with you, stranger.
PHP Inspection Unit (Delphi-Unit zum Analysieren von PHP Code)
  Mit Zitat antworten Zitat
Berni68

Registriert seit: 9. Jan 2006
Ort: Villingen
162 Beiträge
 
Delphi XE5 Professional
 
#5

Re: Stringlist und Objects

  Alt 30. Aug 2009, 10:38
Ok,
das anzupassen krieg ich hin.

Aber

Zitat:
Komponente z.B. nicht verwenden, da in meinen Augen die Stringliste so kein geeigneter Container für eine Objektliste ist, aber das ist Geschmackssache.
heißt doch irgendwie dass der Ansatz insgesamt nicht so gut, oder zumindest unüblich ist.

Wäre es besser TStringList zu vergessen und auf TObjectList (oder Alternative) aufzubauen?
Bernhard
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: Stringlist und Objects

  Alt 30. Aug 2009, 10:53
Ok, D7 und TDE/D2006 kennen es wirklich noch nicht

Ansonsten find ich die Beschreibungen der OH immer sowas von geil und aussagekräftig
Miniaturansicht angehängter Grafiken
tstringlist-eigenschaften_212.png  
$2B or not $2B
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

Re: Stringlist und Objects

  Alt 30. Aug 2009, 13:41
Damit ist doch alles gesagt . Wann immer möglich, greife ich selbst deshalb auch meist auf die alte Hilfe von D7 zurück, die war wenigstens noch brauchbar.
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
Antwort Antwort


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 16:34 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