WalkingNL 2018-11-14 11:29 采纳率: 0%
浏览 595
已结题

Delphi中不同的循环语句,是否会造成性能差异?

循环1:

for i := 1 to 64 do

begin
      TListViewAddColumn(ListView, GetClStr(Colm[i]), taRightJustify, Column[i]);
end;

循环2:

repeat
      TListViewAddColumn(ListView, GetClStr(Colm[i]), taRightJustify, Column[i]);
    pTmpNode := pTmpNode.next;
until pTmpNode = pHeadNode

循环1 以及循环2都执行了64次,循环体中的代码完全一致。不同的地方在于循环2,是对链表节点的访问。就这点差异,造成的结果是 循环2的运行时间明显多于循环1。我测了很多次,循环1的执行时间分布在200 - 300毫秒之间,而循环2的执行时间分布在450 - 600毫秒之间。各位同仁朋友是否有遇到这种情况的,麻烦解答一下,多谢了。

注:为了不造成不必要的误解,我稍微解释一下,循环2中的变量 i其实就是链表每个节点的数据域的值 (pTmpNode.data),即 i = pTmpNode.data, 因为写成pTmpNode.data会使代码很长。

  • 写回答

4条回答

  • hansmile1 2018-11-14 11:38
    关注

    链表是利用有限的内存资源的好方式,同时自然会降低速度;普通方式占用内存大,系统运行不考虑每次的开辟空间与释放,就会快。

    评论

报告相同问题?

悬赏问题

  • ¥15 镍氢电池充电器设计实物使用原理
  • ¥15 逻辑谓词和消解原理的运用
  • ¥15 三菱伺服电机按启动按钮有使能但不动作
  • ¥15 js,页面2返回页面1时定位进入的设备
  • ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号