![]() |
Zuweisung für FOR-Schleifenvariablen wird nicht akzeptiert
Hallo,
der Fehler wird gemeldet: Zitat:
Delphi-Quellcode:
Wieso hat der damit ein Problem dass ich den Schleifenvariablen etwas zuweisen will? Wage glaube ich dass das früher immer geklappt hat?
for la:=0 to max.a do
for lb:=-max.b to max.b do for lc:=-max.c to max.c do begin //jetzt kommt viel blabla //aussenwelt if (maxlauf>5000)or (i mod 10=0 ) then // keine Sorge der kommt da manchmal rein begin application.ProcessMessages; if stop then begin la:=max.a; lb:=max.b; lc:=max.c; end; label2.Caption:=inttostr(maxformel-i); end; //jetzt kommt viel blabla end; Rot makieren tut er das da:
Delphi-Quellcode:
la:=max.a;
|
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
versuchs doch einfach mit "break", du willst ja wie ich das sehe "nur" die Schleifen beenden oder?
|
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Hai Alexander,
den Laufvariablen einer FOR-Schleife kannst Du nichts zuweisen. Diese werden quasi vom Compiler "wegoptimiert". Genauso kannst Du nach der FOR-Schleife nicht auf die Variablen zugreifen. Genauer gesagt haben sie nach der Schleife keinen definierten Wert. Das war aber imho schon immer so. |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
kann es sein, das es ein Problem damit hat,
dass Du die Schleifenvariablen der FOR Schleife in der Schleife veränderst. Da wäre dann wenn ein while oder repeat Schleife besser.
Delphi-Quellcode:
so ähnlich stelle ich mir das vor.
la:=0;
while la < max.a do begin lb:=-max.b; while lb < max.b do begin lc:=-max.c; while lc < max.c do begin //jetzt kommt viel blabla //aussenwelt if (maxlauf>5000)or (i mod 10=0 ) then // keine Sorge der kommt da manchmal rein begin application.ProcessMessages; if stop then begin la:=max.a; lb:=max.b; lc:=max.c; end; label2.Caption:=inttostr(maxformel-i); end; inc(lc); end; /while lc inc(lb); end; //while lb inc(la); end; // while la //jetzt kommt viel blabla Ich mag das mit break nicht. Grüße Klaus |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Zitat:
Hatte es nämlich damit ausprobiert. Zitat:
Dann bleibt mir wohl nichts anderes übrig als in jede for schleife die break variante einzubauen. Also ungefähr so
Delphi-Quellcode:
Falls ich was falsch eingerückt haben sollte. Bitte entschuldigt. Hier ist es mit den Leerzeichen kompliziert einzurücken.
for la:=0 to max.a do
begin for lb:=-max.b to max.b do begin for lc:=-max.c to max.c do begin //jetzt kommt viel blabla //aussenwelt if (maxlauf>5000)or (i mod 10=0 ) then // keine Sorge der kommt da manchmal rein begin application.ProcessMessages; if stop then break; label2.Caption:=inttostr(maxformel-i); end; //jetzt kommt viel blabla end; if stop then break; end; if stop then break; end; |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Also wenn nach der Schleife nixmehr kommt würd ich ein exit empfehlen.
|
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Da kommt noch verdammt viel wichtiges. :???:
Deswegen so umständlich. :roll: |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Es gibt mehrere Möglichkeiten die Schleife zu verlassen.
Hier nur ein paar Möglichkeiten... Abfrage in jeder Schleife:
Delphi-Quellcode:
Label um alle Schleifen direkt zu verlassen (manche mögen kein 'goto'):
begin
for LoopX := 1 to 1000 do begin for LoopY := 1 to 1000 do begin for LoopZ := 1 to 1000 do begin Application.ProcessMessages(); if Stop then Break; //... end; if Stop then Break; //... end; if Stop then Break; //... end; //... end;
Delphi-Quellcode:
Mit Exit die Funktion verlassen (Code nach 'finally' wird nicht ausgeführt):
label
LoopEnd; begin for LoopX := 1 to 1000 do begin for LoopY := 1 to 1000 do begin for LoopZ := 1 to 1000 do begin Application.ProcessMessages(); if Stop then goto LoopEnd; //... end; //... end; //... end; LoopEnd: //... end;
Delphi-Quellcode:
...hat alles seine Vor- und Nachteile.
begin
try for LoopX := 1 to 1000 do begin for LoopY := 1 to 1000 do begin for LoopZ := 1 to 1000 do begin Application.ProcessMessages(); if Stop then Exit; //... end; //... end; //... end; finally //... end; end; |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
dann mach doch ne Funktion/prozedur aus dem Abschnitt! So etwa:
Delphi-Quellcode:
Naja weist schon was ich mein oder?procedure DeineMainPrc; procedure InMainproc(var x,y,a,z,b,c : integer); begin for i:= x to y do for j:= a to z do for k := b to c do begin if stop then exit; end; end; begin InMainProc(x1,x2,x3,x4,x5,x6) end; |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Exit zählt i.A. zu den Jump-Befehlen und wird oft in die Kategorie "GoTo" geworfen. Und da gehört es auch hin, es ist einer der Befehle, die zu unleserlichem Spaghetti-Code führen und nur mit Bedacht, besser aber nie, genutzt werden sollten.
Das dreifache Break, wie von NicoDE gezeigt, ist hier der sauberste Lösungsweg. ...:cat:... |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Zitat:
Um die drei Schleifen zu verlassen, würde ich Goto einsetzen (für mich einer der wenigen sinnvollen Einsatzmöglichkeiten dieses Sprachelements). |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Huh?
Exit, Break und Continue sind der saubere Ersatz fuer goto. Alle drei sind notwendig, aber sollten sparsam eingesetzt werden. In diesem Fall ist Exit die sauberste Moeglichkeit aus der innersten Schleife auszubrechen. Am lesbarsten ist es nur die Schleifen in eine lokale Prozedur zu extrahieren. Der Vorschlag mit try finally ist nicht so leicht zu durchschauen. Es ist auch der effizienteste Weg. Dreifaches Break heisst zwei zusaetzliche Tests. |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Da die Möglichkeit besteht diese Schleifen durch bedingte Schleifen wie "while do" und "repeat until" zu ersetzen sind es diese Sprachkonstrukte die am saubersten sind.
Die Feststellung sie wären "unpraktisch" glaube ich einfach nicht, eher vermute ich das das Problem konzeptionell vom Programmierer falsch angegangen wurde ! Gruß Hagen |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Zitat:
Ausserdem ist es auch viel Geschacksache ob, man jetzt For Schleifen mir break, oder while schleife mit dem Zuweisen der laufvariablen löst. Ich glaub jetzt auch langsam, dass while schleifen da etwas kürzer wären. Tschüss Danke für eure Hilfe |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Ich glaub hier könnte man auch mal wieder das nette goto anwenden :mrgreen:
Delphi-Quellcode:
for la:=0 to max.a do
for lb:=-max.b to max.b do for lc:=-max.c to max.c do begin //jetzt kommt viel blabla //aussenwelt if (maxlauf>5000)or (i mod 10=0 ) then begin application.ProcessMessages; if stop then goto abc; label2.Caption:=inttostr(maxformel-i); end; //jetzt kommt viel blabla end; abc: Zitat:
drumm laß ich dat ma mit dem Beispielcode ... will ja keine "schlechten" Praktiken verbreiten ^^ |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Zitat:
|
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Hi,
Die While-Schleifenlösung ist zwar vom Sprachkonzept her die sauberste, aber in der Realität grauenvoll.
Delphi-Quellcode:
Äh.. sauber? :shock:
i:=0;
While (i<m) and Not AbortedByInnerCode Do Begin j := 0; While (j<n) and Not AbortedByInnerCode Do Begin k := 0; While (k < r) and Not AbortedByInnerCode Do Begin l := 0; While (l < p) and Not AbortedByInnerCode Do Begin If DoSomeThing = DoesNotWork Then AbortedByInnerCode := True; l := l + 1; End; k := k + 1; End; j := j + 1; End; i := i + 1; End; Hier die Goto-Version: Ich finde das besser, weil es lesbarer und *kein* Spaghetticode ist. Denn nicht jedes Goto macht aus Code gleich eine Frickelschusterei. Goto ist ein legitimer Befehl, der -richtig (und damit sparsam!) dosiert- den Code übersichtlicher macht.
Delphi-Quellcode:
Mal ehrlich: Was ist übersichtlicher?
For i:=0 t o m-1 do
For j:=0 to n-1 do For k:=0 to r-1 do For l:=0 to p-1 do If DoSomeThing = DoesnotWork Then Goto ExitLoop; ExitLoop: Ich würde allerdings eine lokale Prozedur verwenden:
Delphi-Quellcode:
Damit sind die Goto-Ablehner zufriedengestellt. Ach so, die lokale Prozedur bekommt natürlich einen aussagekräftigen Namen. Denn eigentlich ist es ein 'ausführbarer Kommentar'.
Procedure OuterProc;
Var m,n,o,p : Integer; Procedure InnerLoop; Var i,j,k,l : Integer; Begin For i:=0 t o n-1 do For j:=0 to m-1 do For k:=0 to o-1 do For l:=0 to p-1 do If DoSomeThing = DoesnotWork Then Exit; End; Begin ... InnerLoop; ... End; Unabhängig davon, ob 4 verschachtelte Schleifen nicht vielleicht ein falsches Konzept/Algorithmus implizieren, ist die Beendigung aus dem inneren von Schleifen eine generelle Frage, die ich, einmal beantwortet, konsistent und konsequent durch den Code ziehen würde. Also Entweder IMMER - mit While-Schleifen arbeiten und einen Flag mitschleppen, ODER - mit Goto arbeiten, ODER - mit lokalen Prozeduren und Exit. Ach, eins noch: Eine andere (sinnvolle) Verwendung für das GOTO fällt mir übrigens nicht ein, Euch etwa? |
Re: Zuweisung für FOR-Schleifenvariablen wird nicht akzeptie
Hi
die Schleifen laufen
Delphi-Quellcode:
von 0 bis m * n * r * p -1, meiner Meinung nach reicht eventuell auch nur eine Schleife aus.
for i := 0 to m-1 do
for j := 0 to n-1 do for k := 0 to r-1 do for l := 0 to p-1 do @Alexander: Ja man könnte es auch "höflicher" ausdrücken: Lieber Alexander, könnte es unter Umständen, ich meine ja nur, vielleicht wäre es sinnvoll dein Problem mal im Gesamtkontext zu erläutern, weil es könnte ja durchaus die klitzekleine Möglichkeit bestehen, das man auf diese vielen Schleifen verzichten kann ? Ändert nichts an der Sache, ich finde meine erste Aussage nicht falsch, noch beleidigend, sondern leider allzuoft eine Tatsache. Also wozu um den heisen Brei reden. Erkläre doch mal dein gesamtes Verfahren. Ansonsten stimme ich Alzaimar zu wenn er den Vorschlag macht mit Exit in einer nested Funktion zu arbeiten. Das ist besser als ein verschachteltes Break/Continue da es dort öfters Probleme gibt beim Verständis wohin nun "ge-breakt"/"ge-continued" wird. Besonders bei Sprachübergreifender Betrachtungsweise stellt sich nämlich heraus das Break/Continue abhängig von der Sprache unterschiedlich arbeiten. Das kann bei Exit/Return() (und meinetwegen auch einem GOTO zu einem LABEL) etc. nicht passieren. Gruß Hagen |
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:06 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