0

我的测试版用户平均每小时看到一次以下崩溃:

0   libobjc.A.dylib                 0x33182f78 objc_msgSend + 16
1   Foundation                      0x3497e4f8 __57-[NSNotificationCenter addObserver:selector:name:object:]_block_invoke_0 + 12
2   CoreFoundation                  0x35530540 ___CFXNotificationPost_block_invoke_0 + 64
3   CoreFoundation                  0x354bc090 _CFXNotificationPost + 1400
4   Foundation                      0x348f23e4 -[NSNotificationCenter postNotificationName:object:userInfo:] + 60
5   Foundation                      0x348f3c14 -[NSNotificationCenter postNotificationName:object:] + 24
6   libdispatch.dylib               0x338f1c52 _dispatch_call_block_and_release + 6
7   libdispatch.dylib               0x338fce8a _dispatch_main_queue_callback_4CF$VARIANT$up + 190
8   CoreFoundation                  0x355372a6 __CFRunLoopRun + 1262
9   CoreFoundation                  0x354ba49e CFRunLoopRunSpecific + 294
10  CoreFoundation                  0x354ba366 CFRunLoopRunInMode + 98
11  GraphicsServices                0x33255432 GSEventRunModal + 130
12  UIKit                           0x32c92cce UIApplicationMain + 1074
13  Ars Logica                      0x00039ecc main (main.m:16)
14  Ars Logica                      0x00039e80 start + 32

我有两个并发症:

1) 我不打电话给 NSNotificationCenter。

2)尽管付出了巨大的努力,但在使用 XCode 运行时,我从未发生过这种情况。

我找不到低内存报告和崩溃事件之间的相关性。

坦率地说,我不确定从这里去哪里。并发症 2 显然是一个大问题。

任何建议或指示将不胜感激。


作为记录,这被证明是 iAd 框架中的一次崩溃。具体来说,我按照 Apple 示例准备好整页插页式广告,但当我进入后台时,我并没有让它失效。当我从后台出来时,有时会向旧上下文发送一条通知,说明广告服务器的附件已丢失。进入后台时使广告上下文无效可以很好地解决所有问题。

4

1 回答 1

4

你最好的选择可能是使用方法调配和一个类别来替换:

+ addObserver:selector:name:object:

NSNotificationCenter中。

使用您自己的版本记录所有参数的内容,然后调用真实版本。这样,当您的测试人员看到崩溃时,他们可以查看设备日志以查看传递给该方法的最后一件事在做什么。这可能会让您有足够的洞察力来确定系统的哪个区域正在使用通知中心。

另外,您使用ARC吗?使用 ARC 如果可能发生这样的错误,我会感到非常惊讶,似乎您正在将某些东西传递到系统中,然后以某种方式在幕后附加到通知,但在系统仍有参考时被释放。

这是与您的需要相关的方法调配的一个示例(替换类级别方法):

如何在 iOS 上调整类方法?

显然,不要将其运送到商店...

于 2013-03-26T03:49:44.077 回答