本文整理自网络,侵删。
TList性能注意事项
本文虽然是用TList为例,但同样适用于Tstringlist,Tobjectlist等列表类。
1)提取/删除列表中的元素
例如,在包含65536个元素的列表中:
while list.Count > 0 do List.Delete(0) //完成需要2分钟
for I := List.Count-1 downto 0 do List.Delete(I) //完成时间少于1秒同样是删除65536个元素,为什么2种方法所需时间相差如此之大?因为删除项目[0]比删除项目[计数-1]慢得多的原因在于它后面有6万多个元素的内存移动。提取元素也是同样的原理。所以我们应该从队尾提取元素,而不是从队头。我们应该从队尾开始删除元素,而不是从队头。
2)查找列表中的元素从没有排序的列表中indexof()元素速度非常慢,而从排序的列表中查找元素的速度非常快。
来源:https://www.cnblogs.com/hnxxcxg/p/13551861.html
相关阅读 >>
Delphi indy tidhttp tidhttpserver post get
Delphi新建服务,停止系统服务,以及获取服务状态和新建系统服务器的方法
Delphi中多线程下使用使用 unidac+mssql 需要注意的问题
Delphi:窗体的扩展样式gwl_exstyle用于setwindowlong
更多相关阅读请进入《Delphi》频道 >>