![]() |
For-Schleife Rückwärts?
Hi,
in D7 beobachte ich im Debugger ein eigenartiges Verhalten:
Delphi-Quellcode:
Die Schleife wird nicht von 1 bis 11 (Wert von Const AnzRep) durchlaufen, sondern von 11 bis 1 - also eigentlich wie "AnzRep DOWNTO 1".
FOR i:=1 TO AnzRep DO
BEGIN Log.Lines.Add(Berichte[i]); [...] END; Muss man das verstehen? Es ist hier nicht kritisch, aber wenn die Reihenfolge der Berichte von Bedeutung wäre, hätte ich doch ein deutliches Problem... habe ich einen Schalter übersehen ("drehe alles um")? Gruß Mark |
Re: For-Schleife Rückwärts?
Hallo,
das ist die automatische Optimierung von Delphi. Wenn die Schleife rückwärts läuft, muss als Abbruchbedingung nur auf Null getestet werden, was schneller geht. Die Optimierung hat aber keine negativern Auswirkungen auf Deinen Code, das wird vom Compiler entsprechend angepasst. Gruß xaromz |
Re: For-Schleife Rückwärts?
Danke - sowas hatte ich vermutet... woher weiß Delphi denn, dass das nicht kritisch ist? In der Schleife rufe ich die Load- und Save-Methoden von Fastreport auf. Es könnte doch gut sein, dass ich die Reihenfolge der Reports fix haben möchte...
Gruß Mark |
Re: For-Schleife Rückwärts?
Hallo,
Zitat:
Delphi-Quellcode:
wird zu
for i := 1 to 10 do
Memo.Lines[i] := IntToStr(i);
Delphi-Quellcode:
Alles in Butter also.
for i := 9 downto 0 do
Memo.Lines[10 - i] := IntToStr(10 - i); Gruß xaromz |
Re: For-Schleife Rückwärts?
Ouch - das ist eine böse Falle... habe mir gerade den Debug-Output angeschaut und bemerkt, dass die Reihenfolge tatsächlich OK ist - geht man im Debugger auf "Berichte[i]" wird aber der falsche Bericht angezeigt (der ist dann gerade gar nicht dran). Also wohl besser Optimierung aus beim debuggen.
Gruß & vielen Dank! Mark |
Re: For-Schleife Rückwärts?
Zitat:
Kann man dieses "Feature" eigentlich abschalten, ohne auf die Optimierung zu verzichten ? |
Re: For-Schleife Rückwärts?
Ich glaube nicht, dass sich der logische Durchlauf einer Schleife durch diese Optimierung in irgendeiner Art ändert. Die Optimierung bezieht sich auf Geschwindigkeit und Codeeffizienz. In meiner ganzen Delphi-Zeit (vlt. 10 Jahre) konnte ich kein Problem durch "optimierte" For-Schleifen feststellen.
|
Re: For-Schleife Rückwärts?
Siehe dazu auch:
![]() |
Re: For-Schleife Rückwärts?
Daß der Debugger bei eingeschalteter Optimierung in manchen Schleifen spinnt, hat mir auch schon Kopfzerbrechen gekostet; inzwischen findet sich das z.B. hier in CodeGears Quality Central:
Report No: 33195 (RAID: unavailable) Status: Open Watches not working in optimized for loop ![]() |
Re: For-Schleife Rückwärts?
Zitat:
|
Re: For-Schleife Rückwärts?
Hallo
@TeronG wie kommst du darauf, das es in "seltenen" Fällen was ausmacht, in der Praxis aber nicht. ich find die aussage breiig! Bastel doch mal was um deine Aussage zu unterstützen! mfg DerDan |
Re: For-Schleife Rückwärts?
Zitat:
In MEINEM bescheidenen Progger-alltag war das noch nie n Problem (so weit ich weis ^^) und zur unterstützung meiner Meinung hatte ich ja "Nuclear-Ping" zitiert (vlt. 10 Jahre ohne Probleme). |
Re: For-Schleife Rückwärts?
Ich bin nun seit Delphi 1 dabei - mit wechselnder Intensität - und mir ist das auch noch nie unangenehm aufgefallen. Normalerweise schalte ich die Optimierung nur für die "Finale" Compilierung ein, weil mir die ständig nicht mehr vorhandenen Variablen sonst das Leben schwer machen. Nur gestern hatte ich eine "optimierte" Anwendung "mal schnell" noch an einer Stelle überarbeiten wollen. Der Aufruf von FastReport.LoadFile gab jedes 7. Mal ein "Invalid File Format" - egal, welcher Report der siebte war. Nach dem Hinweis darauf, dass in Wirklichkeit "Report[11-i]" aufgerufen wurde statt "Report[i]", war sonnenklar, welcher Report der "böse" war. Nochmals also sehr herzlichen Dank für den Tipp!
Aber wie gesagt - das ist gestern das erste mal gewesen, dass ich darüber gestolpert bin. Gruß Mark |
Re: For-Schleife Rückwärts?
Hallo und sorry das ich diesen alten Thread auskrame.
Ich stolper zum 2. mal über diese "Optimierung" und zum 2. mal muss ich die For-Schleife aus dem Programmcode nehmen, da sonst ein komplettes Fehlverhalten auftritt. Ich habe folgenden Code:
Delphi-Quellcode:
for i := low(AZiffer) to high(AZiffer)-1 do begin //Prüfungen der Ziffern... if AZiffer[i,0] = '5.' then begin // Hier springt er JEDESMAL in dn den IF Block wenn Aziffer[i,0] = '0.1' und das ist FALSCH // wenn er bei 5. angelangt ist springt er über die Bedingung und sagt False. // Ergo ein komplettes Fehlverhalten. //Hier wird ein Stringzusammen gebastelt. end; end; edit: zu früh gepostet... verdammtes Tab ;) |
Re: For-Schleife Rückwärts?
Delphi-Quellcode:
Sollte die Schleife nicht bis High(AZiffer) laufen.
for i := low(AZiffer) to high(AZiffer)-1 do begin
//Prüfungen der Ziffern... Da High ja den letzen Index des Array repräsentiert. Grüße Klaus |
Re: For-Schleife Rückwärts?
nd du solltest Fließkommawerte mie auf Göleichheit prüfen.
|
Re: For-Schleife Rückwärts?
Das sind doch Strings die ich vergleiche.
Zu dem High: Das -1 ist an der Stelle schon ok. |
Re: For-Schleife Rückwärts?
Ich kann dieses Verhalten (BDS2006 Pro) nicht nachvollziehn.
Du musst aber nicht zwingend auf die For-Schleife verzichten. Per Compilerdirektiven {O+-} kannst du die Optimierung für bestimmte Codeblöcke ausschalten. greetz Mike |
Re: For-Schleife Rückwärts?
Ok damit geht es.
Danke... Der Tag fängt echt super an x) :wall: |
Re: For-Schleife Rückwärts?
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 15:23 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