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 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名
  • ¥65 汇编语言除法溢出问题