![]() |
Re: Listbox - Seletierte Einträge
@Yheeky: Du bist Dir aber schon im Klaren, das Rekursion für dieses Problem nicht gerade die sinnvollste Lösung ist... :roll:
...:cat:... |
Re: Listbox - Seletierte Einträge
Mal eine etwas ausführlichere Begründung, warum man nicht Elemente einer Liste in einer vorwärts-laufenden Schleife löschen kann - bzw. warum es zu Exception kommt.
Wenn die Schleife gestartet wird, speichert Delphi im ECX-Register die Gesamtzahl der Iterationen für die Schleife. Das ist eine Optimierung um schnell zu sein. ;-) Dieses Register wird mit jedem Durchlauf heruntergezählt und nicht neu überprüft. Werden jetzt während des Durchlaufes Elemente gelöscht, so will Delphi immer noch alle ursprünglich vorhandenen Elemente durchlaufen... :arrow: Index out of Bounds. Wer unbedingt vorwärts durch die Schleife luafen muss, sollte es mit einer while Schleife lösen:
Delphi-Quellcode:
...:cat:...
var I: Integer;
... I := 0; while I < Items.Count-1 do begin ...... Inc(I); end; ... |
Re: Listbox - Seletierte Einträge
Ihr versteht meine Intention nicht...ich wollte keine "bessere" Lösung vorstellen, sondern hatte nur gefragt, warum es (angeblich) nicht vorwärts gehen soll:
Zitat:
Zitat:
@Sakura: Rekursion ist eine häufig verwendete Programmierart, deswegen kann man sie nicht oft genug verwenden :wink: Gruß Yheeky |
Re: Listbox - Seletierte Einträge
Zitat:
Zitat:
In fast allen Fällen ist Rekursion extrem viel langsamer als Iteration. Weshalb sollte man die dann nutzen, wenn es einfacher mit einer Iteration zu lösen ist. Rekursion hat ihre Berechtigung, aber bestimmt nicht in diesem Falle ;-) Speziell hier ist die Lösung dadurch sehr, sehr viel langsamer und umständlicher. Für eine Dateisuche über eine gesamte HD würde ich Rekursion immer der Iteration vorziehen, da diese (wenn auch langsamer) garantiert übersichtlicher ist. Aber in diesem Falle doch nicht... ...:cat:... |
Re: Listbox - Seletierte Einträge
Du hast mich beim 2.Mal falsch zitiert, bzw. den Smiley vergessen -> :wink: <-
Das Rekursion häufig verwendet wird, war schon mein ernst, aber das man es selbst oft verwenden soll, war natürlich nur Spaß :D Gruß Yheeky |
Re: Listbox - Seletierte Einträge
Na gut :D
...:cat:.. |
Re: Listbox - Seletierte Einträge
Wunderbar! Dann hat sich doch noch alles zum Guten gewendet :lol:
Gruß Yheeky |
Re: Listbox - Seletierte Einträge
ich hab folgende erfahrung mit rekursion:
ich musste mal die fibonacci-zahlen für die schule programmieren. fast alle habens mit rekurstion gemacht, da hats ca. 5x so lang gebraucht und bei hohen zahlen war der kellerspeicher plötzlich voll!!! :shock: ich würde rekursion nur dann verwenden, wenns nix anderes gibt!!! [für alle, die nicht wissen, was fibonacci-zahlen sind: fibonacci(n) = fibonacci(n-1) + fibonacci(n-2) fibonacci(1) = fibonacci(2) = 1] |
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:12 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 by Thomas Breitkreuz