键入时搜索大型Core-Data数据集

问题描述

| 我有一个很大的核心数据数据集,我想添加搜索支持。目前,我正在使用提取的结果控制器在uitableview中显示数据。我正在计划使用UISearchdisplayController。现在我有两个选择: 为搜索的数据创建一个新的获取结果控制器 使用数组显示过滤后的数据 哪种方法更合适/建议(尤其是按类型搜索)?是否有书籍或教程介绍如何实施建议的解决方案?     

解决方法

在几个项目中,我使用了“新的获取结果控制器”选项,因为我过滤的数据可能会耗尽旧版iPhone中的所有内存。 FRC可以处理内存不足的问题。如果您选择此选项,此stackoverflow答案可能对您有所帮助 您的数据是否足够小以适合最低公分母(第一代iPhone)的可用内存?如果是这样,那么只需使用NSArray在内存中过滤即可。在性能方面,这将比使用FRC更快。     ,是否不断写入数据?我有一组1,200条记录,可以通过“包含”搜索进行搜索。我在应用程序启动时所做的工作是包含一个对象,该对象包含基于coredata存储的所有数据集。如果数据在应用程序使用过程中得到更新-将重新构建数据集。 然后,当我进入搜索表视图时,将搜索预加载的数据。每次进行提取都会导致过多的延迟-即使使用了写得好的谓词和提取的结果控制器也是如此。我发现手动进行处理要快得多,因为我可以创建数据子集以加快搜索速度。 希望这有助于您做出决定。 干杯, 麦可     

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...