delphi – 为什么相同的代码在线程中执行得更快?
发布时间:2020-12-15 04:25:31 所属栏目:大数据 来源:网络整理
导读:考虑这个非常简单的代码: 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;
考虑这个非常简单的代码:
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; 这个简单的循环在我的PC上执行4027 ms.现在如果我写相同的代码,只使用不同的线程: 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',val])); end); end ).Start; end; 该方法执行相同但在不同的线程执行2910毫秒! (在Delphi XE中编译,释放配置有效)我注意到线程中增加了25%,无论我有多少次迭代.为什么是这样的?不应该是一样的结果吗? 编辑: 解决方法
确实很奇怪,但也许是因为一些偏移量c.q.对准.
也许匿名线程中的变量是正确对齐的,另一个不是. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |