Невозможно увидеть объекты зомби в xcode 4.2
У меня было приложение, которое раньше нормально работало в ios4 и более ранних версиях os, но теперь я вижу частое EXC_BAD_ACCESS при попытке запустить его на симуляторе для ios5. К сожалению, я сейчас на xcode 4.2 и не могу видеть свои объекты-зомби, когда получаю ошибку.
Приложение никогда не вылетает на телефоне, но оно постоянно вылетает на симуляторе, поэтому я хочу увидеть причину сбоя, прежде чем отправлять обновление. Всякий раз, когда я получаю ошибку (и это происходит из нескольких представлений), я получаю
int retVal = UIApplicationMain(argc, argv, nil, nil); Thread 1: Program received signal: "EXC_BAD_ACCESS"
Я включил NSZombie как на экране диагностики, так и на вкладке переменных, но пока ничего не вижу. Даже добавление строки в didFinishLaunchingWithOptions, которая целенаправленно выпускает один и тот же объект несколько раз, дает мне эту ошибку при запуске, но никогда не сообщается как NSZombie.
Что я делаю неправильно?
Кроме того, когда эти ошибки происходят, это то, что я вижу в окне отладки. Это похоже на трассировку стека, но есть ли способ получить номера строк с ним?
#0 0x020b609b in objc_msgSend ()
#1 0x002ba9d0 in -[NSURLConnectionInternal initWithInfo:] ()
#2 0x002bb4df in -[NSURLConnectionInternalConnection initWithInfo:] ()
#3 0x002ba0af in -[NSURLConnection(Private) _initWithRequest:delegate:usesCache:maxContentLength:startImmediately:connectionProperties:] ()
#4 0x002ba1f6 in -[NSURLConnection initWithRequest:delegate:] ()
#5 0x002ba17b in +[NSURLConnection connectionWithRequest:delegate:] ()
#6 0x01f13d81 in +[NSObject performSelector:withObject:] ()
#7 0x001df9ef in __NSThreadPerformPerform ()
#8 0x01ee697f in __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ ()
#9 0x01e49b73 in __CFRunLoopDoSources0 ()
#10 0x01e49454 in __CFRunLoopRun ()
#11 0x01e48db4 in CFRunLoopRunSpecific ()
#12 0x01e48ccb in CFRunLoopRunInMode ()
#13 0x02775879 in GSEventRunModal ()
#14 0x0277593e in GSEventRun ()
#15 0x00516a9b in UIApplicationMain ()
#16 0x00055919 in main at /Volumes/Data/xxxx/Classes/internal/main.m:14
#17 0x00002d75 in start ()
1 ответ
Обычно проще всего отлаживать зомби с помощью инструментов. Для этого есть предустановленный / шаблонный инструмент. Инструменты остановят вашу программу, когда зомби будут отправлены сообщения, и вы даже можете использовать ее для просмотра каждой операции подсчета ссылок.