gpt4 book ai didi

delphi - 为什么相同的代码在线程中执行得更快?

转载 作者:行者123 更新时间:2023-12-03 14:41:48 26 4
gpt4 key购买 nike

考虑这段非常简单的代码:

uses Diagnostics;

const
ITER_COUNT = 100000000;

procedure TForm1.btn2Click(Sender: TObject);
var
val: Double;
i: Integer;
begin
sw := TStopwatch.StartNew;

val := 1;
for i := 0 to ITER_COUNT - 1 do
begin
val := val + i;
val := val - i;
val := val * 10;
val := val / 10;
end;

sw.Stop;

mmo1.Lines.Add(Format('Simple completed in %D ms. Result: %G',
[sw.ElapsedMilliseconds, val]));
end;

这个简单的循环在我的电脑上执行时间为 4027 毫秒。现在,如果我编写相同的代码,仅使用不同的线程:

procedure TForm1.btn3Click(Sender: TObject);
begin
sw := TStopwatch.StartNew;
TThread.CreateAnonymousThread(
procedure
var
val: Double;
i: Integer;
begin
val := 1;
for i := 0 to ITER_COUNT- 1 do
begin
val := val + i;
val := val - i;
val := val * 10;
val := val / 10;
end;

sw.Stop;

TThread.Queue(nil, procedure
begin
mmo1.Lines.Add(Format('Async completed in %D ms. Result: %G',
[sw.ElapsedMilliseconds, val]));
end);
end
).Start;
end;

此方法执行相同的操作,但在不同的线程中,执行时间为 2910 毫秒! (在 Delphi XE 中编译,发布配置处于事件状态)我注意到,无论我有多少次迭代,线程都会获得约 25% 的增益。为什么会这样呢?不应该是同样的结果吗?

编辑:经过进一步调查,我发现这可能是Windows 7操作系统的原因。在 Windows 7 机器上,主线程中的简单循环执行速度比异步版本慢约 25%!我什至尝试使用 Windows XP 模式在同一台 Windows 7 PC 上运行相同的项目,然后两个结果相同 - ~3000ms!我完全迷失了...Windows 7 的主线程速度变慢了,这是在做什么?

最佳答案

确实很奇怪,但也许是因为一些偏移c.q。对齐。

也许匿名线程中的变量是正确对齐的,而另一个则没有。您可以尝试添加一些虚拟变量来更改偏移量,或者如果您有 Delphi XE2,请尝试一些不同的 code alignment .

关于delphi - 为什么相同的代码在线程中执行得更快?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8922759/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com