我的测试版用户平均每小时看到一次以下崩溃:
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 示例准备好整页插页式广告,但当我进入后台时,我并没有让它失效。当我从后台出来时,有时会向旧上下文发送一条通知,说明广告服务器的附件已丢失。进入后台时使广告上下文无效可以很好地解决所有问题。