Come determinare quale nsnotificazione si sta schiantando a causa di un osservatore di dealloc.
Domanda
La regola d'oro dell'uso NSNotification
sembra essere
"chiamata
removeObserver
prima diobserver
(o ilobject
) è deallocato ".
Ho a che fare con una base di codice in cui questa regola non è stata seguita, ma non riesco a individuare la trasgressione. Ho cercato tramite il codice e ho assicurato che tutti addObserver
ha una corrispondenza removeObserver
Ma sto ancora vedendo rapporti sugli incidenti della seguente varietà:
OS Version: iPhone OS 5.0.1 (9A405)
Report Version: 104
Exception Type: SIGSEGV
Exception Codes: SEGV_ACCERR at 0x8
Crashed Thread: 0
Thread 0 Crashed:
0 libobjc.A.dylib 0x31516fbc objc_msgSend + 16
1 Foundation 0x3195b50f __57-[NSNotificationCenter addObserver:selector:name:object:]_block_invoke_0 + 19
2 CoreFoundation 0x37a02577 ___CFXNotificationPost_block_invoke_0 + 71
3 CoreFoundation 0x3798e0cf _CFXNotificationPost + 1407
4 Foundation 0x318cf3fb -[NSNotificationCenter postNotificationName:object:userInfo:] + 67
5 UIKit 0x34e5ee25 -[UIApplication _handleApplicationSuspend:eventInfo:] + 697
6 UIKit 0x34deed17 -[UIApplication handleEvent:withNewEvent:] + 2031
7 UIKit 0x34dee3bf -[UIApplication sendEvent:] + 55
8 UIKit 0x34dedd2d _UIApplicationHandleEvent + 5809
9 GraphicsServices 0x3750bdf3 PurpleEventCallback + 883
10 CoreFoundation 0x37a0a553 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 39
11 CoreFoundation 0x37a0a4f5 __CFRunLoopDoSource1 + 141
12 CoreFoundation 0x37a09343 __CFRunLoopRun + 1371
13 CoreFoundation 0x3798c4dd CFRunLoopRunSpecific + 301
14 CoreFoundation 0x3798c3a5 CFRunLoopRunInMode + 105
15 GraphicsServices 0x3750afcd GSEventRunModal + 157
16 UIKit 0x34e1c743 UIApplicationMain + 1091
17 App 0x00002d2f main (main.m:14)
La mia interpretazione di questo rapporto di crash è quella [UIApplication _handleApplicationSuspend:eventInfo:]
sta pubblicando una notifica per la quale un osservatore è stato traffico prima di essere rimosso.
Supponendo che queste interpretazioni siano corrette, Come vorrei determinare quale notifica viene pubblicata? E idealmente, quale tipo di oggetto deallocato?
Soluzione
Puoi impostare un punto di interruzione simbolico in -[NSNotificationCenter postNotificationName:object:userInfo:]
e stampare il terzo argomento passato ad esso (il primo è il NSNotificationCenter
, il secondo, _cmd
) usando il debugger po
comando.
Altri suggerimenti
Un altro modo per determinare questo è ottenere il valore del parametro del nome (la stringa passata per la pubblicazione della notifica) e verificare che qualsiasi oggetto che sta osservando che la stringa/nome sia impostato per rimuovere l'osservazione qualche volta nel ciclo di vita degli oggetti o mentre si sta affidando.