Delphi-PRAXiS
Seite 2 von 2     12   

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 Listbox - Seletierte Einträge (https://www.delphipraxis.net/7449-listbox-seletierte-eintraege.html)

sakura 12. Aug 2003 17:09

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:...

sakura 12. Aug 2003 17:14

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:
var I: Integer;
...
  I := 0;
  while I < Items.Count-1 do
  begin
    ......
    Inc(I);
  end;
...
...:cat:...

Yheeky 12. Aug 2003 17:16

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: Warum sollte es "vorwärts" zu Problemen kommen?
Darauf kam die Antwort von Tpercon:

Zitat:

Weil dann sonst das löschen nicht geht, da die Schleife zu weit laufen würde.
Das wollte ich hier lediglich widerlegen, sonst nichts. Nur falls jemand die "Vorwärtsvariante" interessieren sollte...

@Sakura: Rekursion ist eine häufig verwendete Programmierart, deswegen kann man sie nicht oft genug verwenden :wink:

Gruß Yheeky

sakura 12. Aug 2003 17:21

Re: Listbox - Seletierte Einträge
 
Zitat:

Zitat von Yheeky
Rekursion ist eine häufig verwendete Programmierart

Stimmt.

Zitat:

Zitat von Yheeky
deswegen kann man sie nicht oft genug verwenden

Meinst Du das ernst :shock:

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:...

Yheeky 12. Aug 2003 17:29

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

sakura 12. Aug 2003 17:41

Re: Listbox - Seletierte Einträge
 
Na gut :D

...:cat:..

Yheeky 12. Aug 2003 23:16

Re: Listbox - Seletierte Einträge
 
Wunderbar! Dann hat sich doch noch alles zum Guten gewendet :lol:

Gruß Yheeky

Illuminator-23-5 13. Aug 2003 00:15

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.
Seite 2 von 2     12   

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