
我正在尝试显示一组数据,一个目录.在目录中我有部门和人员.我知道这听起来像是一本教科书的例子,听我说.我保证,这不是家庭作业. (我可以提供我正在处理的截图.)
我有一系列条目,其中有两种目录条目.我需要按名称对条目进行排序,然后将数组拆分为更小的数组,其中每个子数组包含以相同字母开头的条目.
此外,我需要考虑用户可能输入的搜索字符串.
我的一般过程是这样的:
>筛选与类型匹配的所有条目和搜索字符串(如果有).对于此步骤,我使用nspredicate:
nspredicate *predicate = [nspredicate predicateWithFormat:@"type == %i AND searchableContents B[cd] %@",type,searchString];if (!searchString || searchString.length == 0){ predicate = [nspredicate predicateWithFormat:@"type == %i",type];}NSArray *array = [_directoryContents filteredArrayUsingPredicate:predicate]; >按字母顺序对结果进行排序.
array = [array sortedArrayUsingComparator:^NSComparisonResult(ID obj1,ID obj2) { return [((BRKDirectoryEntry *)obj1).comperableTitle compare:((BRKDirectoryEntry *)obj2).comperableTitle];}]; >将结果分解为更小的数组.为了提高性能,如果我们正在搜索,我会跳过此步骤,但它似乎没有帮助.
if(Alphabetized){ array = [self _AlphabetizedArrayFromPresortedArray:array];} 总共950个条目的表现非常糟糕.
现在,对于我的默认显示,我可以简单地将已排序的数据缓存在内存中,然后显示和滚动效果很好,但对于I类搜索,根本无法实现用户期望的平滑性能.
任何指针或提示?
解决方法 是.忘记文件并将其保存在数据库中.创建索引Everything成为一个简单的SQL语句. 总结以上是内存溢出为你收集整理的ios – 快速搜索和排序全部内容,希望文章能够帮你解决ios – 快速搜索和排序所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)