- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有选择。
我有一些已经订购的字符串需要存储和访问。看来我可以选择使用:
TStringList
动态字符串数组,以及
字符串链接列表(单链接)
艾伦在评论中建议我也添加选择:
TList<string>
在什么情况下这些方法比其他方法更好?
哪一个最适合小型列表(10 项以下)?
哪一个最适合大型列表(超过 1000 个项目)?
哪一个最适合大型列表(超过 1,000,000 项)?
哪一个最能最大限度地减少内存使用?
哪种方法最能缩短最后添加额外项目的加载时间?
哪一个最能最大限度地减少从头到尾访问整个列表的时间?
在此基础上(或任何其他),哪种数据结构更可取?
作为引用,我使用的是 Delphi 2009。
<小时/>迪米特里在评论中说道:
Describe your task and data access pattern, then it will be possible to give you an exact answer
好的。我有一个包含大量数据的家谱程序。
对于每个人,我都有许多事件和属性。我将它们存储为短文本字符串,但每个人都有很多,从 0 到几百个不等。我有成千上万的人。我不需要随机访问它们。我只需要将它们关联为按已知顺序附加到每个人的多个字符串。这是我的数千个“小 list ”的案例。它们需要时间来加载和使用内存,如果我需要它们,则需要时间来访问它们(例如导出整个生成的报告)。
然后我有一些更大的列表,例如我的“虚拟” TreeView 的所有部分的名称,其中可以有数十万个名称。同样,我只需要一个可以通过索引访问的列表。为了提高效率,它们与 TreeView 分开存储,并且 TreeView 仅在需要时检索它们。这需要一段时间来加载,并且对于我的程序来说内存非常昂贵。但我不必担心访问时间,因为一次只访问几个。
希望这能让您了解我正在努力实现的目标。
附:我在 StackOverflow 上发布了很多有关优化 Delphi 的问题。我的程序读取 100,000 人的 25 MB 文件,并在 8 秒内为他们创建数据结构、报告和 TreeView ,但需要使用 175 MB RAM。我正在努力减少这种情况,因为我的目标是在 32 位 Windows 中加载数百万人的文件。
<小时/>我刚刚在这个 StackOverflow 问题中发现了一些优化 TList 的极好建议: Is there a faster TList implementation?
最佳答案
除非您有特殊需求,否则 TStringList
很难被击败,因为它提供了许多组件可以直接使用的 TStrings
接口(interface)。使用TStringList.Sorted := True
,将使用二分搜索,这意味着搜索将非常快。您还可以免费获得对象映射,每个项目还可以与一个指针关联,并且您可以获得所有现有的编码、流接口(interface)、逗号文本、分隔文本等方法。
另一方面,出于特殊需要,如果需要进行多次插入和删除,那么更接近链表的东西会更好。但搜索会变得更慢,而且它确实是一个罕见的字符串集合,永远不需要搜索。在这种情况下,经常使用某种类型的哈希,例如,根据字符串的前 2 个字节创建哈希(预分配长度为 65536 的数组,并将字符串的前 2 个字节直接转换为哈希)索引在该范围内),然后在该哈希位置,存储一个链表,其中每个项目键由字符串中的剩余字节组成(为了节省空间——哈希索引已经包含前两个字节)。然后,初始哈希查找的时间复杂度为 O(1),后续的插入和删除都是链表快速的。这是一个可以操纵的权衡,并且杠杆应该是明确的。
关于delphi - Delphi 中的 TStringList、动态数组还是链接列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2680635/
我希望创建类似“TOwnedStringList”(类名是虚构的)的东西,我可以将其构造为: sl := TOwnedStringList.Create(Self); sl.Sorted := Tru
我的环境: C++ Builder XE4 我正在尝试使用 TStringList 的数组使用 unique_ptr<> . 以下没有给出任何错误: unique_ptr vals(new int [
是的,我想将一个简单的日志文件读取到 TStringList 中,使用 LoadFromFile 可以轻松完成。但问题是该文件可能已经被另一个程序同时打开,因此可能会出现异常。我尝试使用: FileM
我有一个用于在 TStringList 中存储许多字符串的应用程序。这些字符串在很大程度上彼此相似,并且我想到可以即时压缩它们 - 即以唯一文本片段加上对先前存储的片段的引用的混合形式存储给定的字符串
可以在没有任何形式同步的情况下从 TStringList 读取数据吗?例如与主线程同步。 示例代码 var MyStringList:TStringList; //declared globally
Delphi 1 16 位(是的,它很旧,但运行良好) 一些示例代码: procedure TForm1.Button1Click(Sender: TObject); var SL: TStrin
Delphi 2007中有没有集成的解决方案来检查TStringList是否包含某个值的一部分? 例如: List.AddObject('This is a string', customString
我正在向 TStringList 添加一些 TObject 后代,例如通过调用 AddObject。我希望当我释放列表对象时它们也被释放。有什么办法可以实现这一点吗? 最佳答案 OwnsObjects
最近,一位信誉良好的 SO 用户通知我,TStringList 存在拆分错误,这会导致它无法解析 CSV 数据。我还没有被告知这些错误的性质,并且在互联网上进行了搜索,包括 Quality Centr
我用 tstringlist 制作了一个非常简单的日志。我将其写入文件: pLog.SaveToFile(FileName); 某处出现错误,我的计算机已关闭。之后,我找不到我的日志文件。可能该文件以
我正在开发一个键盘 Hook 并使用 SetWindowsHookEx,并将每个击键添加到 TStringList 中。为了操纵 TStringList 内的击键,我总是使用“.Text”属性。例如,
我有两个正在使用的字符串列表。一个具有关键字列表,另一个具有否定关键字列表。我希望能够搜索列表并挑选出不包含否定关键字的列表项并输出到第三个关键字列表。我使用的是 AnsiPos 函数,但是如果否定关
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve th
因此,我有几个要读取并从中获取值的摘要文件。 我正在执行以下操作: OutputSummary := TStringList.Create; for idx := 0 to 82 do Outpu
我有一个自定义排序 TStringList ... Items.CustomSort(@CompareWords); ...使用此比较功能: function CompareWords(List: T
procedure FreeListObjects( l : TStrings); var i : integer; BEGIN FOR i := 0 TO l.Count -1 DO BEG
我正在使用 Delphi 7,并且有一个例程,该例程获取包含一系列记录的 csv 文件并导入它们。这是通过使用 MyStringList.LoadFromFile(csvfile) 将其加载到 TSt
我花了好几天时间寻找如何做到这一点,但没有什么是我真正需要做的(或者我只是不明白如何实现该解决方案)。 我需要做的是将一个字符串(街道地址)解析为 TStringList,然后将列表中的这些字符串设置
我试图在 TStringList 的对象属性内存储一个集合(并读取它)(我还将使用它来存储与该集合关联的文本),但我得到了该集合的无效类型转换。 在 StringList 对象中存储集合的最佳方法是什
我正在编写自己的类来管理 android/ios 应用程序的翻译,并且我已经生成了此代码。我将解释下面的代码,但它非常简单且简短。 unit Localization; interface uses
我是一名优秀的程序员,十分优秀!