0

这是我遇到的问题。应用程序运行时,我有几项任务要在后台完成。当我通过将这些任务推送到并发调度队列来在后台运行这些任务时,完成所有这些任务需要超过 10 秒。他们基本上从磁盘加载数据并解析它并将结果呈现给用户。也就是说,它们只是缓存的结果,极大地改善了用户体验。

此缓存结果用于应用程序内部的特定功能,当打开应用程序后未立即使用该功能时,加载支持该功能的数据需要 10 秒,这不是问题,因为当用户决定使用它,该数据将已经加载。

但是当用户打开应用程序后立即在应用程序中输入该功能时,加载数据需要相当长的时间(从用户的角度来看)。此外,在同一时刻不需要全部数据,而是在给定时刻需要它的一部分。这就是为什么我们需要同时加载数据,如果可能的话,尽快带来结果。这就是为什么我决定将数据分成块,当用户请求数据时,我们应该通过后台线程加载相应的块并赋予该线程最高优先级。我会解释我的意思。

想象一下,有 100 条数据,加载它们需要 10 多秒。每当用户第一次查询数据时,应用程序都会确定用户需要哪个数据块并开始加载该数据块。加载该部分后,其余数据也将在后台加载,以使以后的查询更快(没有加载缓存的延迟)。但是这里出现了一个问题,当用户决定在他已经输入查询后立即更改查询,并且该更改发生在例如数据加载过程的第二秒(请记住加载数据需要超过 10 秒,我们仍然有超过 8 秒的时间来完成加载过程),那么在极端情况下,用户将等待直到所有数据都加载完毕才收到他的数据。那' 我需要以某种方式管理后台任务的执行。也就是说,当用户改变输入时,我应该改变执行的优先级,给加载相应chunk的线程最高优先级而不停止它,这样它会获得更多的处理器时间,并且会更快完成,并将结果传递给用户比我保持优先级相同时更快。我知道我可以为队列分配优先级。但是有没有一种方法可以在它们仍在执行时动态更改它们?或者我是否需要实现自定义线程管理才能实现这些行为?我真的不想深入研究线程管理,如果可以仅使用调度或操作队列来实现,我会很高兴。并为加载相应块的线程提供最高优先级而不停止它,因此它将获得更多的处理器时间,并且会更快地完成,并且比我保持优先级相同的情况下更快地将结果传递给用户。我知道我可以为队列分配优先级。但是有没有一种方法可以在它们仍在执行时动态更改它们?或者我是否需要实现自定义线程管理才能实现这些行为?我真的不想深入研究线程管理,如果可以仅使用调度或操作队列来实现,我会很高兴。并为加载相应块的线程提供最高优先级而不停止它,因此它将获得更多的处理器时间,并且会更快地完成,并且比我保持优先级相同的情况下更快地将结果传递给用户。我知道我可以为队列分配优先级。但是有没有一种方法可以在它们仍在执行时动态更改它们?或者我是否需要实现自定义线程管理才能实现这些行为?我真的不想深入研究线程管理,如果可以仅使用调度或操作队列来实现,我会很高兴。比我保持优先级不变的情况要好得多。我知道我可以为队列分配优先级。但是有没有一种方法可以在它们仍在执行时动态更改它们?或者我是否需要实现自定义线程管理才能实现这些行为?我真的不想深入研究线程管理,如果可以仅使用调度或操作队列来实现,我会很高兴。比我保持优先级不变的情况要好得多。我知道我可以为队列分配优先级。但是有没有一种方法可以在它们仍在执行时动态更改它们?或者我是否需要实现自定义线程管理才能实现这些行为?我真的不想深入研究线程管理,如果可以仅使用调度或操作队列来实现,我会很高兴。

我希望我已经很好地描述了这个问题。如果不是,请在下面评论不清楚的地方,我会解释。

非常感谢您到目前为止的阅读:) 并特别感谢提供答案的人。非常感谢一位,他将使用调度或操作队列为我提供解决方案:)))

4

2 回答 2

1

我认为您需要放弃考虑队列运行的优先级(这实际上对于您所描述的场景来说并不重要),而更多地考虑如何使用 Dispatch I/O 或更简单的 Dispatch source 来控制数据的读取方式。正如您所说,加载数据需要 10 秒,如果用户在询问后立即更改查询,您需要基本上停止读取前一个请求的数据并执行任何操作需要完成最近的查询。使用 Dispatch I/O 来分块数据(异步)并异步更新 UI 将允许您在中途改变主意(使用某种信号量或取消标志)并继续将数据滴入(您不需要)t 说明如果用户改变主意,这些数据是否仍然有用),暂停阅读过程,或完全取消它并开始新的操作。无论哪种方式,能够暂停/恢复一个源并让它为相当小的数据块触发回调肯定会让您在比 8 秒更精细的时间块上做出决策!

于 2013-09-11T03:01:29.440 回答
0

恐怕唯一的方法是在开始新的操作之前取消正在运行的操作。在完成或取消之前,您无法将其从队列中删除。

作为对您的问题的改进,我建议即使用户在后台不需要它们,也可以加载它们 - 这样您就可以在缓存之后从缓存中加载它们。

您可以创建 2 个具有 2 个不同优先级的 NSOperationQueue,并在用户在 LowPriorityQueue 上空闲时在后台下载内容。对于重要的操作,您可以拥有高优先级队列 - 您将在每次搜索词更改时取消。

最重要的是,您只需要缓存这两个队列的结果。

于 2013-09-10T13:27:16.437 回答