什么可能导致这次崩溃?

时间:2010-11-19 02:12:47

标签: iphone selector nsnotificationcenter

我最近因使用NSNotificationCenter发布通知时未找到选择器而崩溃。可能导致此错误的原因是什么?

我注意到在发布通知后没有调用用户代码,因此在通知的接收方似乎没有问题。但是,什么可能导致NSNotificationCenter崩溃?

这是电话的堆栈跟踪:

0   libSystem.B.dylib               0x00078ac8 __kill + 8
1   libSystem.B.dylib               0x00078ab8 kill + 4
2   libSystem.B.dylib               0x00078aaa raise + 10
3   libSystem.B.dylib               0x0008d03a abort + 50
4   libstdc++.6.dylib               0x00044a20 __gnu_cxx::__verbose_terminate_handler() + 376
5   libobjc.A.dylib                 0x00005958 _objc_terminate + 104
6   libstdc++.6.dylib               0x00042df2 __cxxabiv1::__terminate(void (*)()) + 46
7   libstdc++.6.dylib               0x00042e46 std::terminate() + 10
8   libstdc++.6.dylib               0x00042f16 __cxa_throw + 78
9   libobjc.A.dylib                 0x00004838 objc_exception_throw + 64
10  CoreFoundation                  0x000a167c -[NSObject(NSObject) doesNotRecognizeSelector:] + 96
11  CoreFoundation                  0x000491d2 ___forwarding___ + 502
12  CoreFoundation                  0x00048f88 _CF_forwarding_prep_0 + 40
13  Foundation                      0x000146ac _nsnote_callback + 136
14  CoreFoundation                  0x0002670c __CFXNotificationPost_old + 396
15  CoreFoundation                  0x000263ac _CFXNotificationPostNotification + 112
16  Foundation                      0x0000b014 -[NSNotificationCenter postNotification:] + 132
17  [My Application]                0x000a5ad2 -[PortfolioUpdateOperation main] (PortfolioUpdateOperation.m:37)
18  Foundation                      0x0000e9e8 -[__NSOperationInternal start] + 652
19  Foundation                      0x0000e74c -[NSOperation start] + 16
20  Foundation                      0x00023574 ____startOperations_block_invoke_2 + 40
21  libSystem.B.dylib               0x000d597c _dispatch_call_block_and_release + 12
22  libSystem.B.dylib               0x000d675c _dispatch_worker_thread2 + 120
23  libSystem.B.dylib               0x0007a67a _pthread_wqthread + 258
24  libSystem.B.dylib               0x00073190 start_wqthread + 0

3 个答案:

答案 0 :(得分:3)

很可能NSNotificationCenter正在尝试通知不再存在的对象实例。

换句话说,取消分配对象而不将其自身移除为NSNotificationCenter观察者。检查代码是否存在对象将自身添加为NSNotificationCenter观察者但无法从NSNotificationCenter中删除的情况。

答案 1 :(得分:3)

看起来您添加了一个对象作为不响应您提供的选择器的观察者。确保您的通知方法接受一个NSNotification

类型的参数

答案 2 :(得分:0)

也许对respondsToSelector进行检查,然后记录对象的类名等可以帮助你进一步?