我发现很难想象您提供的代码样本具有不同的性能特征的情况。
我确实对你有好奇心。在类似Pascal的语言(例如Delphi)中,循环限制仅评估一次。这与类似C的语言不同,后者在每次迭代时都会评估循环极限。这可能会对性能产生影响,但是通过在循环外引入局部变量,以类似C的语言编写高性能代码当然很简单。
例如:
德尔菲
for i := 0 to List.Count-1 do DoStuff(List[i]);
List.Count仅被评估一次。
C ++
for (int i=0; i<List.getCount(); i++) DoStuff(List.getItem(i));
在这里,
List.getCount()每次循环都被调用。
如果发现评估回路极限是昂贵的,则该差异可能是相关的。自然,
List.getCount()在循环外求值并将结果存储在局部变量中是很简单的。
比较了
forPascal和C / C ++
的循环后,我会说Pascal版本在比较中非常简单。这不一定是一件坏事,因为对于更复杂的应用程序总有
while可用的方法。



