Инструменты XCode не обнаруживают зомби с помощью BAD_ACCESS - PullRequest
0 голосов
/ 15 ноября 2011

Обычно, когда я пытаюсь исправить ошибку BAD_ACCESS, я открываю Инструменты Xcode и проверяю, чтобы найти зомби, которые вызывают ошибку.

Я запускаю свое приложение с симулятором iPhone 5.0. Он останавливается на BAD_ACCESS, но инструменты не помечают зомби.

Поведение совершенно другое, когда я запускаю приложение с симулятором iPhone 4.3. В этом случае приложение работает очень хорошо без BAD_ACCESS.

Я использую XCode 4.2.

Что может происходить?

Вот обратный след:

(gdb) bt
#0  0x0167209b in objc_msgSend ()
#1  0x00002ff2 in -[BSViewController viewDidAppear:] (self=0x1, _cmd=0x12ddd81, animated=1 '\001') at BSViewController.m:42
#2  0x012616f8 in __CFStringAppendFormatCore ()
#3  0x011acb6c in _CFStringCreateWithFormatAndArgumentsAux ()
#4  0x0122bce8 in _CFLogvEx ()
#5  0x00b26b63 in NSLogv ()
#6  0x00b26ad5 in NSLog ()
#7  0x00009ffc in -[BSCTView buildFrames] (self=0x6a55f80, _cmd=0xd541) at BSCTView.m:96
#8  0x0000a5da in -[BSCTView layoutSubviews] (self=0x6a55f80, _cmd=0x66a6c4) at BSCTView.m:124
#9  0x001ff301 in -[UIView(CALayerDelegate) layoutSublayersOfLayer:] ()
#10 0x01284e72 in -[NSObject performSelector:withObject:] ()
#11 0x0283592d in -[CALayer layoutSublayers] ()
#12 0x0283f827 in CA::Layer::layout_if_needed ()
#13 0x027c5fa7 in CA::Context::commit_transaction ()
#14 0x027c7ea6 in CA::Transaction::commit ()
#15 0x0285330c in +[CATransaction flush] ()
#16 0x001bf4c6 in -[UIApplication _reportAppLaunchFinished] ()
#17 0x001bfbd6 in -[UIApplication _runWithURL:payload:launchOrientation:statusBarStyle:statusBarHidden:] ()
#18 0x001ce743 in -[UIApplication handleEvent:withNewEvent:] ()
#19 0x001cf1f8 in -[UIApplication sendEvent:] ()
#20 0x001c2aa9 in _UIApplicationHandleEvent ()
#21 0x01748fa9 in PurpleEventCallback ()
#22 0x012571c5 in __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ ()
#23 0x011bc022 in __CFRunLoopDoSource1 ()
#24 0x011ba90a in __CFRunLoopRun ()
#25 0x011b9db4 in CFRunLoopRunSpecific ()
#26 0x011b9ccb in CFRunLoopRunInMode ()
#27 0x001bf2a7 in -[UIApplication _run] ()
#28 0x001c0a9b in UIApplicationMain ()
#29 0x000027a0 in main (argc=1, argv=0xbffff578) at main.m:16

1 Ответ

5 голосов
/ 16 ноября 2011

Как сказано выше @AdamRosenfield, в комментариях к вопросу EXC_BAD_ACCESS может быть вызвано многими другими вещами, которые не являются зомби.

В данном конкретном случае проблема была NSLog() сстрока формата, которая ожидала объект @"%@" и получала int в качестве параметра, как показано ниже.

int variable = 1;
NSLog(@"%@", variable);

Это вызывало EXC_BAD_ACCESS.

После чтенияВ обратном следе я увидел эту строку #6 и обыскал все NSLog() вызовы кода, чтобы, наконец, найти тот, который содержит ошибку.

...