gpt4 book ai didi

ios - NSOperationQueues 中的信号量

转载 作者:行者123 更新时间:2023-12-03 17:19:36 29 4
gpt4 key购买 nike

我第一次尝试基于 Swift/NSOperationQueue 的设计,我正在尝试找出如何维护跨队列的数据完整性。

我处于设计过程的早期阶段,但该架构可能会涉及一个队列(称为sensorQ),用于处理来自各种传感器的传感器测量数据流,这些传感器将为融合模型提供数据。传感器数据将以各种速率传入,有些非常快(例如加速度计数据),但有些需要扩展计算,可能需要一秒或更长时间。

我想弄清楚如何将当前状态捕获到用户界面中。 UI 必须由主队列(称为 mainQ)处理,但会反射(reflect)融合引擎的当前状态。

我不想在传感器队列上发生的每次更新都影响 UI 线程,因为它们可能会非常频繁地发生,因此 NSOperationQueue.mainQueue.addOperationWithBlock() 调用将状态传回对于用户界面来说似乎不可行。出于同样的原因,我不想将查询发送到传感器队列,因为如果它正在处理很长的计算,我将阻止等待它。

我正在考虑设置一个 NSTimer,它可以每隔十分之一秒左右将状态复制到 UI 中。

为此,我需要确保在将状态复制到 UI 队列的同时,传感器队列上的状态不会更新。看起来像是信号量的工作,但我并没有太多提及与 NSOperationQueues 相关的信号量。

我在 Grand Central Dispatch 中找到了对 dispatch_semaphore_t 对象的引用。

所以我的问题基本上是,处理这些情况的推荐方法是什么?我看到反复警告要在最高抽象级别(NSOperationQueue)工作,除非您需要较低级别(例如 GCD)的优化。这是我需要优化的情况吗? dispatch_semiphore_t 可以与 NSOperationQueue 一起使用吗?这里有我忽略的基于 NSOperationQueue 的方法吗?

最佳答案

您要向 UI 发送多少数据?几个数字?复杂的图表?

如果您正在 NSOperationQueue(我们称之为sensorQ)上处理所有传感器数据,为什么不使队列串行呢?然后,当计时器触发时,您可以将“更新 UI”任务发布到sensorQ。当您的更新任务到达传感器 Q 时,您知道没有其他传感器正在修改状态。您可以捆绑数据并发布到主 (UI) 队列。

如果我们知道: 1. 你们的传感器有最小和最大数据速率吗? 2. 有多少传感器对您的融合模型做出了贡献? 3. 您如何同步从传感器到融合模型的访问? 4. UI“更新”了多少数据、以什么格式?

我的直觉是,不需要信号量。

关于ios - NSOperationQueues 中的信号量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37041158/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com