Delphi-PRAXiS

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/)
-   -   Delphi Dyn. Array oder TList (https://www.delphipraxis.net/76147-dyn-array-oder-tlist.html)

hoika 30. Aug 2006 15:49


Dyn. Array oder TList
 
Hallo #,

ich erweitere gerade eine Grid-Komponente.
Sie ist was gaanz spezielles mit speziellen Events für Datenbank-Eingaben,
und kann nicht so einfach durch was anderes ersetzt werden,
also bitte keine Antwort wie "nimm doch das oder das dafür".

Ich will zu einer Spalte ein paar Infos (in einer Klasse) hinterlegen.
Die Infos kommen von den jeweiligen Forms
und werden im OnDrawCell ausgewertet.


Da das Grid dynamisch Spaltenanzahl hat,
ist die Frage, was ich für die Infos benutzen soll.

(Objects wird schon verwendet, dass kann ich nicht nehmn)

Da nicht alle Spalten Infos bekommen, dachte ich an eine Liste (TList)
oder halt ein dynamisches Feld mit je einem Eintrag pro Spalte.

was ist denn schneller beim Suchen mit Qucksort ?


Danke im voraus

Heiko

3_of_8 30. Aug 2006 15:56

Re: Dyn. Array oder TList
 
Beim Sortieren dürfte das ziemlich egal sein. Sowohl Dynamische Arrays als auch TLists haben Random Access.

Khabarakh 30. Aug 2006 16:02

Re: Dyn. Array oder TList
 
Da beide ein lineares Array darstellen (oder besser gesagt: TList verwendet selbst wiederum ein Array), sind beide gleichschnell, nur ein minimaler Overhead kommt bei TList durch die Getter- und Setter-Aufrufe hinzu.
Dafür ist eben das Adden eines Eintrages durch die exponentielle Vergrößerung um Einiges schneller.

[edit]Hm... muss wohl schneller schreiben :stupid: . [/edit]

JasonDX 30. Aug 2006 16:17

Re: Dyn. Array oder TList
 
Ich wuerde eine TList verwenden. Intern arbeiten sowohl TList als auch ein dynamisches Array ueber den selben Weg, allerdings hat TList einige Vorteile:
  • Du haelst deinen Code frei von Dingen wie
    Delphi-Quellcode:
    setLength(MyArray, length(MyArray) + 1);
    MyArray[High(MyArray)] := blubb;
  • Ein List.Add(blubb); sieht sauber aus, und man erkennt sofort, was es macht -> Code wird leserlicher
  • Geht TList einher mit dem Konzept der OOP
  • Sind die wichtigsten Methoden zum Arbeiten mit Listen (wie bspw. Add, Delete, Move, Sort) bereits vorimplementiert
Nachteil ist - wie bereits erwaehnt, dass Getter- und Setter-Aufrufe knapp mehr Zeit benoetigen.
Kurz um: Wenn du eine angenehme Loesung willst, nimm TList. Wenn du etwas mehr Schreibarbeit fuer einen kleinen winzigen Geschwindigkeitsvorteil in Kauf nimmst, dann verwende dynamische Arrays.

greetz
Mike

hoika 30. Aug 2006 16:38

Re: Dyn. Array oder TList
 
Hallo,

da fällt mir gerade ein,
ich könnte ja prinzipiell so viele List-Einträge erzeugen
wie Spalten, dann greife ich direkt darauf zu über den Index.
Auf die Idee bin ich gar nicht gekommen !!!

*Schulter klopf*

:cheers:

Heiko

3_of_8 30. Aug 2006 16:45

Re: Dyn. Array oder TList
 
Sogar winzig ist noch übertrieben. Das dürften 2-3 Assemblerschritte sein. Jeder moderne Prozessor haut die mit Pipelining weg wie nommal was.

=> Fällt überhaupt nicht auf.

himitsu 30. Aug 2006 16:56

Re: Dyn. Array oder TList
 
Zitat:

Zitat von 3_of_8
Sogar winzig ist noch übertrieben. Das dürften 2-3 Assemblerschritte sein. Jeder moderne Prozessor haut die mit Pipelining weg wie nommal was.

=> Fällt überhaupt nicht auf.

Es kommt aber darauf an, wie oft man die dann aufruft ... mit der Zeit kann sich das schon summieren ;)

3_of_8 30. Aug 2006 16:59

Re: Dyn. Array oder TList
 
Ich glaub bevor das auffällt geht eher der Speicher aus oder es gibt nen Integer Overflow. :mrgreen:

Und in einer normalen VCL Anwendung dürfte das gar nicht so oft aufgerufen werden.

Khabarakh 30. Aug 2006 17:10

Re: Dyn. Array oder TList
 
Kleiner Hinweis: Ich meinte nicht nur den Call-Overhead, sondern auch den Inhalt des Getters und Setters :zwinker: . Wobei der Zusatz-Overhead des Getters (und ein Teil des Setters) durch eine aktivierte Bereichsprüfung wieder ausgeglichen wäre.


Alle Zeitangaben in WEZ +1. Es ist jetzt 09:55 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-2025 by Thomas Breitkreuz