Einzelnen Beitrag anzeigen

Benutzerbild von himitsu
himitsu

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

Re: SetLength / Getmem / AllocMem out of memory Problem

  Alt 8. Okt 2009, 10:36
Bei Google suchenverkettete Liste

das ganze nochmal kurz als Array ... zum Vergleich
Delphi-Quellcode:
TData = record
  name: String;
  typ: Integer;
  ...
end;

TAsArray = Array of TData;
eine einfach verkettete Liste
Delphi-Quellcode:
PListe = ^TListe;
TListe = record
  next: PListe;

  name: String;
  typ: Integer;
end;

var myList: PListe;
bei dieser verketten Liste ist es so, daß nur der Zeiger auf das erste Element in der Liste bekannt ist
und jede Element kennt dann seinen Nachfolger ... du kannst dich also vom ersten element aus zu allen anderen Elementen durchhangeln


und das wäre dann eine doppelt verkettete Liste
Delphi-Quellcode:
PListe = ^TListe;
TListe = record
  prev: PListe;
  next: PListe;

  name: String;
  typ: Integer;
end;

var myList_first: PListe;
    myList_last: PListe;
hier kennt dann jedes Element auch noch seinen Vorgänger ... das macht es dann einfacher diese Liste zu "editieren" (zu verändern, wie z.B. Einträge einzufügen oder zu entfernen)


Der Vorteil gegenüber dem Array ist dann einfach, daß diese Daten nicht stur alle in einer Reihe angeordnet sein müssen ... sie können sich also frei im verfügbaren Speicher verteilen und brauchen keinen gemeinsamen Speicherblock.


Was jetzt aber für dich eine "gute" Lösung wäre, das kommt darauf an, wie der Zugriff auf deine Daten aussieht, wie/ob diese auch mal verändert werden und vorallem welche und wieviele Daten du in jedem Element drinnen hast.

z.B. bei einem Array of String wäre es Schwachsinn dieses als verkettete Liste verwalten zu wollen, da so der Speicherverbrauch und auch der Verwaltungsaufwand wesentlich höher wäre, als beim Array.
$2B or not $2B
  Mit Zitat antworten Zitat