Delphi-PRAXiS
Seite 7 von 7   « Erste     567   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   String in TStringList finden verschnellern? (https://www.delphipraxis.net/191366-string-tstringlist-finden-verschnellern.html)

haentschman 9. Jan 2017 17:41

AW: String in TStringList finden verschnellern?
 
Das müssen den TE fragen. Er kämpft mit den Milisekunden... :wink:

a.def 9. Jan 2017 18:43

AW: String in TStringList finden verschnellern?
 
Zitat:

Zitat von mjustin (Beitrag 1358508)
Was andererseits zu der Frage führt: was fangen wir nun mit den eingesparten 100-950 Millisekunden an? :-D

Mit
Delphi-Quellcode:
Sleep(600);
sollte das Problem erledigt sein :stupid:

p80286 9. Jan 2017 22:44

AW: String in TStringList finden verschnellern?
 
Zitat:

Zitat von haentschman (Beitrag 1358494)
Natürlich muß man die Zeit berücksichtigen in der die Listen aufgebaut werden. Das stand aber nicht zur Debatte...:thumb:

Was habe ich davon wenn der Zugriff in 0,001 MS erfolgt, aber vorher 2 h vorbereitet wird?

Gruß
K-H

a.def 9. Jan 2017 22:47

AW: String in TStringList finden verschnellern?
 
Zitat:

Zitat von haentschman (Beitrag 1358511)
Das müssen den TE fragen. Er kämpft mit den Milisekunden... :wink:

Nee ;) Mir ging es um eine relativ große Dauer welche ich vernichten wollte.
Denn der Unterschied zwischen 1 Minute und 5 Sekunden ist schon gewaltig.

himitsu 10. Jan 2017 00:22

AW: String in TStringList finden verschnellern?
 
Zitat:

Zitat von p80286 (Beitrag 1358526)
Was habe ich davon wenn der Zugriff in 0,001 MS erfolgt, aber vorher 2 h vorbereitet wird?

Es kommt auf den Verwendungsfall drauf an.

Wenn sich die Liste oft ändert, aber nur selten darauf zugegriffen wird, dann kann die Suche langsamer sein, aber das Hinzufügen/Löschen/Ändern sollte schnell sein,
aber wenn die Liste sich selten ändert und oft gesucht wird, dann natürlich andersrum.

Und dann kann man noch unterscheiden wie die Liste gefüllt wird.
Wird sie einmal schnell gefüllt und es gibt zwischendrin keine Zugriffe, dann kann man dabei die Sortierung/Indizierung aus lassen (falls möglich) und führt das erst nach dem Befüllen durch. (beim Dictionary nicht möglich, aber bei der TStringList, wenn man beim Befüllen selber auf Dupplikate achtet)

mjustin 10. Jan 2017 09:07

AW: String in TStringList finden verschnellern?
 
Zitat:

Zitat von himitsu (Beitrag 1358528)
Wird sie einmal schnell gefüllt und es gibt zwischendrin keine Zugriffe, dann kann man dabei die Sortierung/Indizierung aus lassen (falls möglich) und führt das erst nach dem Befüllen durch. (beim Dictionary nicht möglich, aber bei der TStringList, wenn man beim Befüllen selber auf Dupplikate achtet)

Beim TDictionary ist es nicht möglich, aber auch nicht notwendig, da jedes neue Element ohne Sortierung einfach an der Stelle abgelegt wird, die sich aus dem Hashwert ergibt.

himitsu 10. Jan 2017 09:19

AW: String in TStringList finden verschnellern?
 
Jain.
Bei der Vergrößerung der Liste müssen ab und an mal alle Einträge neu positioniert werden, wenn der interne Speicher die Größe ändert.

freimatz 10. Jan 2017 17:21

AW: String in TStringList finden verschnellern?
 
Hat noch keiner einen AVL-Baum ausprobiert? :-D
Der ist beim Einfügen und beim Suchen recht schnell.

EmWieMichael 10. Jan 2017 18:03

AW: String in TStringList finden verschnellern?
 
Zitat:

Zitat von freimatz (Beitrag 1358604)
Hat noch keiner einen AVL-Baum ausprobiert? :-D
Der ist beim Einfügen und beim Suchen recht schnell.

Ich habe zwar keinen AVL-Baum getestet, aber ich habe mal eine Zeigerliste gegen TStringlist mit 1.000.000 20stelligen Zufallsstrings antreten lassen (unsortiert) und dabei in den Listen den vorletzten String gesucht. Die zeigerverkettete Liste ist rund sechsmal schneller.

Zacherl 10. Jan 2017 18:32

AW: String in TStringList finden verschnellern?
 
Zitat:

Zitat von EmWieMichael (Beitrag 1358612)
Zitat:

Zitat von freimatz (Beitrag 1358604)
Hat noch keiner einen AVL-Baum ausprobiert? :-D
Der ist beim Einfügen und beim Suchen recht schnell.

Ich habe zwar keinen AVL-Baum getestet, aber ich habe mal eine Zeigerliste gegen TStringlist mit 1.000.000 20stelligen Zufallsstrings antreten lassen (unsortiert) und dabei in den Listen den vorletzten String gesucht. Die zeigerverkettete Liste ist rund sechsmal schneller.

Das wundert mich ehrlich gesagt. Linked-Lists sollten bei sequenzieller Suche in etwa gleich schnell sein wie ein Array (bzw. eine intern als Array implementierte List).


Alle Zeitangaben in WEZ +1. Es ist jetzt 09:05 Uhr.
Seite 7 von 7   « Erste     567   

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