鉴于您提供的详细信息,我会概括一下,但这是我可以解决的方法:
首先,我会设置比 1000 条记录小得多的批量大小。如果结果计数或“任何人都想看到的最多”是不确定的(听起来就像你的情况),用户可能甚至不会关心前 100 个左右。如果您的用户经常请求一个大而昂贵的列表,并且立即想要查看距离开头那么远的内容,他们在停下来环顾四周之前将滚动条向下扔了两分钟,那么可能需要更直观的排序顺序而不是询问 Google用于 1000 多个动画小猫 GIF 的图像。;-)
表视图背后的控制器(绝对是基于视图的视图重用)表视图将需要某种请求队列,因为我假设您正在批量处理,因为单独检索它们的成本很高。这将管理异步请求/okay-now-it's-loaded 机器(我知道这很模糊,但需要更多细节才能更具体)。您将确保任何“当前处于活动状态”的视图都会以某种方式获得此“准备就绪”通知,并将从一些“忙碌”的 UI 状态转到显示准备好的项目(因为我们永远不想让表等待准备就绪-在给定行显示对象的视图,因此该视图至少应该显示一些“仍在等待详细信息”指示,以便快速滚动很多行不会停止任何事情)。
使用基于视图的 NSTableView 和相关的数据源方法将让表格视图处理只保留足够的自定义 NSTableCellView 副本以在滚动期间重用。由于您必须在询问时提供已配置的视图,因此视图的默认状态可以是“如果未准备好则不绘制任何内容”或一些视觉上通用的占位符,直到对象实现并准备好(然后您可以重新加载该行而不是整个表)。这样,表格会保持快速滚动和绘制,因为它不关心您的控制器正在做什么来履行更新可见行的承诺(您的自定义单元格视图将观察其表示的对象的更新)。
如果上限是天文数字,您可能希望滚动条反映到目前为止批处理的总行数 - 反映该大小会使滚动条抓地力既小又非常敏感。相反,只需按照用户到目前为止“请求”的内容(通过表格视图的行数)增加滚动条,一直到列表的开头。每当有更多批处理时,您都需要将批处理大小添加到控制器的批处理总行数中。这仍然可以让滚动条按用户无法以那种速度区分的行缩放。您可以通过发送表视图-noteNumberOfRowsChanged
并回复其生成的数据源请求(-numberOfRowsInTableView:
) 将更新后的总行数存储在控制器的属性中。它会根据需要请求新可见行的视图(在像以前一样实现之前,它将处于某种中性的、未实现的视觉状态),更新滚动视图,起泡,冲洗,重复。
您可以使用NSCache
以保持较低的内存使用率。将其设置countLimit
为批处理大小的几倍,如果它决定需要转储前n 个模型对象,则让它丢弃以前的批处理,然后如果表视图突然要求查看批处理窗口中不再存在的行的视图,则将它们批处理范围。
如果不了解更多关于您的需求和架构的信息,就很难获得更具体的信息。如果我没有达到目标,请考虑编辑您的问题以包含更多细节。如果我完全偏离您的要求,请澄清。:-)