Frage

Ich habe erst seit kurzem einen Absturz über einen Wähler nicht gefunden werden, wenn eine Meldung geschrieben wurde mit NSNotificationCenter. Was kann diesen Fehler verursachen?

Ich habe bemerkt, dass es kein Code Benutzer aufgerufen wird, nachdem die Meldung geschrieben wurde, so ist das kein Problem auf der Empfangsseite der Mitteilung zu sein scheint. Doch was könnte dazu führen, NSNotificationCenter zum Absturz bringen?

Hier ist der Stack-Trace des Anrufs:

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
War es hilfreich?

Lösung

Wahrscheinlich NSNotificationCenter versucht, eine Objektinstanz zu benachrichtigen, dass nicht mehr vorhanden ist.

Mit anderen Worten wurde ein Objekt ausgeplant, ohne sich als Beobachter NSNotificationCenter zu entfernen. Überprüfen Sie den Code für die Fälle, wenn ein Objekt fügt sich als NSNotificationCenter Beobachter aber nicht entfernen sich von NSNotificationCenter.

Andere Tipps

Sieht aus wie Sie hinzugefügt, ein Objekt als Beobachter, der nicht an den Wähler reagieren Sie zur Verfügung gestellt. Stellen Sie sicher, dass Ihre Benachrichtigungsmethode akzeptiert ein Argument vom Typ NSNotification

Vielleicht folgte eine Überprüfung, um respondsToSelector mit einiger Protokollierung des Klassennamen des Objekts usw. Ihnen weiter helfen könnte?

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top