今天我遇到了很奇怪的bug. 我有下一个代码: var i: integer;...for i := 0 to FileNames.Count - 1 dobegin ShowMessage(IntToStr(i) + ' from ' + IntToStr(FileNames.Count - 1)); FileName := FileNames[i]; ...end; ShowMessage('all'
我有下一个代码:
var i: integer;
...
for i := 0 to FileNames.Count - 1 do
begin
ShowMessage(IntToStr(i) + ' from ' + IntToStr(FileNames.Count - 1));
FileName := FileNames[i];
...
end;
ShowMessage('all');
FileNames列表有一个元素.所以,我认为然后循环将被执行一次,我看到了
0 from 0 all
这是我做了几千次的事情:).
但是在这种情况下,我看到了代码优化开启时的第二次循环迭代.
0 from 0 1 from 0 all
没有代码优化循环迭代正确.
目前我甚至不知道移动这个问题的方向(并且上部循环绑定保持不变,是).
所以任何建议都会非常有帮助.谢谢.
我使用Delphi 2005(Upd2)编译器.
考虑到LU RD提到的质量控制报告,以及我自己对D2005的经验,这里有一些解决方法.我记得自己使用while循环解决方案.1.将for循环写为while循环
var
i: integer;
begin
i := 0;
while i < FileNames.Count do
begin
...
inc(i);
end;
end;
2.从任何其他处理中单独保留for循环控制变量,并使用一个单独的变量,在循环中递增,用于字符串操作和FileNames索引.
var
ctrl, indx: integer;
begin
indx := 0;
for ctrl := 0 to FileNames.Count-1 do
begin
// use indx for string manipulation and FileNames indx
inc(indx);
end;
end;
你暗示了一个解决方法,说没有代码优化循环迭代正确.假设你有优化,在程序/函数之前关闭它({$O-}),之后再关闭({$O}).注意! Optimization指令只能用于至少整个过程/函数.
