- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个应用程序,它使用 NSOperations
来管理对 Web API 的服务调用(这些调用基于 CURLOperation in Jon Wight's touchcode )。
本地图 View 的中心发生显着变化时,有一个特定的调用会下载 map 位置;因为这些可以很快堆积起来,如果你移动 map ,我会尝试积极取消陈旧的操作。它在 4.0 上运行良好。
但是,在 3.1 中,似乎在某些情况下操作队列将保留已取消(和释放)的操作,从而在到达它们应在队列中的位置时导致崩溃。
这是一个插图。
我从队列中相对重量级的服务调用开始:
MyLongRunningOp 0x1
用户导航至 map 。队列现在看起来像这样:
MyLongRunningOp 0x1
MyMapOp 0x2
他们移动 map ,取消 MyMapOp 0x2 并添加 MyMapOp 0x3:
MyLongRunningOp 0x1
MyMapOp 0x3
MyMapOp 0x2
现已发布,因为它已从队列中删除。现在,MyLongRunningOp 0x1
完成。在用于设置 MyLongRunningOp
上 isFinished 键的 KVO 回调中,我看到操作队列处理通知并尝试将 MyMapOp 0x2
添加到某些 NSArray
>。当然,启用 NSZombies
后,
[MyMapOp retain]: message sent to deallocated instance 0x2
似乎 NSOperationQueue
以某种方式卡在指向已取消/已释放操作的指针上,并尝试在前一个操作完成后激活它。
我无法在 4.0 上重现此行为,因此我认为这是 3.1 的错误。
我在解决这个问题时遇到了很多麻烦 - 据我所知,唯一的解决方法是永远不要取消我的操作,这会在网络不稳定时导致体验不佳。
还有其他人经历过这种情况吗?有什么想法吗?
最佳答案
我在 NSOperations 上使用 KVO 时遇到了(我认为是)类似的问题。
刚刚阅读您的描述,我的第一 react 是检查操作队列的规则。是否有可能一旦您将其交给队列,队列就应该承担所有权,因此您不应该手动释放它? (不确定你是否是)。
根据我的个人经验,也许这会有所帮助,也可能没有帮助:
1) 当您取消操作时,请从中删除 KVO 观察者。我遇到过这样的情况:当任何一方被删除时,KVO 都不会取消链接。
2) 请注意,KVO 回调与 NSOperation 在同一线程中运行。因此,在您开始操作和 KVO 回调之间,对象可能会超出范围。
如果您发布代码,我也许可以为您提供更多帮助。希望以上内容对您有用!
关于iphone - 为什么 iPhone OS 3.1 上的 NSOperationQueue 会保留长期取消(和释放)的操作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3670309/
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 5年前关闭。 Improve this
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我试图弄清楚如何基于 JSESSIONID cookie 为具有长期交互式用户 session 的 web 应用程序提供零停机滚动更新,这些 session 应该是粘性的。 出于这个(和其他)原因,我
这更像是一个“你能给我指出正确的方向吗”类型的问题。 基本上,我想为客户提供一种“保存”购物车的方法,也许以后可以与亲戚一起查看(这是摄影师客户的“照片篮”)。 当使用我的“照片篮”时,它会创建一个篮
我正在编写一个使用商店的网络应用程序。如果客户端在30秒内没有收到响应,则认为该请求已失效,并给出超时错误。 我正在尝试让 MongoDB 做同样的事情。例如,如果连接断开 1 分钟,驱动程序将尝试重
我多年来一直在开发和管理 Oracle 数据库应用程序,并且想学习 SQL Server。有没有人有任何书籍推荐(最好是电子版)。当然,我已经对 SQL 了如指掌,所以我想避免任何介绍性的内容,直接进
我是一名优秀的程序员,十分优秀!