AGB  ·  Datenschutz  ·  Impressum  







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

Dyn. Array oder TList

Ein Thema von hoika · begonnen am 30. Aug 2006 · letzter Beitrag vom 30. Aug 2006
Antwort Antwort
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#1

Dyn. Array oder TList

  Alt 30. Aug 2006, 16:49
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
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von 3_of_8
3_of_8

Registriert seit: 22. Mär 2005
Ort: Dingolfing
4.129 Beiträge
 
Turbo Delphi für Win32
 
#2

Re: Dyn. Array oder TList

  Alt 30. Aug 2006, 16:56
Beim Sortieren dürfte das ziemlich egal sein. Sowohl Dynamische Arrays als auch TLists haben Random Access.
Manuel Eberl
„The trouble with having an open mind, of course, is that people will insist on coming along and trying to put things in it.“
- Terry Pratchett
  Mit Zitat antworten Zitat
Benutzerbild von Khabarakh
Khabarakh

Registriert seit: 18. Aug 2004
Ort: Brackenheim VS08 Pro
2.876 Beiträge
 
#3

Re: Dyn. Array oder TList

  Alt 30. Aug 2006, 17:02
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 . [/edit]
Sebastian
Moderator in der EE
  Mit Zitat antworten Zitat
Benutzerbild von JasonDX
JasonDX
(CodeLib-Manager)

Registriert seit: 5. Aug 2004
Ort: München
1.062 Beiträge
 
#4

Re: Dyn. Array oder TList

  Alt 30. Aug 2006, 17:17
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
Mike
Passion is no replacement for reason
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#5

Re: Dyn. Array oder TList

  Alt 30. Aug 2006, 17:38
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*



Heiko
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von 3_of_8
3_of_8

Registriert seit: 22. Mär 2005
Ort: Dingolfing
4.129 Beiträge
 
Turbo Delphi für Win32
 
#6

Re: Dyn. Array oder TList

  Alt 30. Aug 2006, 17:45
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.
Manuel Eberl
„The trouble with having an open mind, of course, is that people will insist on coming along and trying to put things in it.“
- Terry Pratchett
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: Dyn. Array oder TList

  Alt 30. Aug 2006, 17:56
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
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  Mit Zitat antworten Zitat
Benutzerbild von 3_of_8
3_of_8

Registriert seit: 22. Mär 2005
Ort: Dingolfing
4.129 Beiträge
 
Turbo Delphi für Win32
 
#8

Re: Dyn. Array oder TList

  Alt 30. Aug 2006, 17:59
Ich glaub bevor das auffällt geht eher der Speicher aus oder es gibt nen Integer Overflow.

Und in einer normalen VCL Anwendung dürfte das gar nicht so oft aufgerufen werden.
Manuel Eberl
„The trouble with having an open mind, of course, is that people will insist on coming along and trying to put things in it.“
- Terry Pratchett
  Mit Zitat antworten Zitat
Benutzerbild von Khabarakh
Khabarakh

Registriert seit: 18. Aug 2004
Ort: Brackenheim VS08 Pro
2.876 Beiträge
 
#9

Re: Dyn. Array oder TList

  Alt 30. Aug 2006, 18:10
Kleiner Hinweis: Ich meinte nicht nur den Call-Overhead, sondern auch den Inhalt des Getters und Setters . Wobei der Zusatz-Overhead des Getters (und ein Teil des Setters) durch eine aktivierte Bereichsprüfung wieder ausgeglichen wäre.
Sebastian
Moderator in der EE
  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 00:45 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