有什么可以导致这会崩溃吗?
-
26-09-2019 - |
题
我最近收到的有关通知时使用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
解决方案
最有可能的NSNotificationCenter试图通知对象实例不再存在。
换句话说,对象被释放而不去除本身作为一个NSNotificationCenter观察者。检查你的代码的情况下,当一个对象增加了自己作为一个观察者NSNotificationCenter,但无法将自己从NSNotificationCenter删除。
其他提示
像您长得添加对象为不到您提供的选择器响应一个观察者。确保您的通知方法接受类型NSNotification
的一个参数
也许一个检查respondsToSelector
随后与对象的类名的一些记录等可以帮助你进一步?
不隶属于 StackOverflow