2013-04-29 33 views
0

我已經從我的iOS應用程序的bugsense一些崩潰報告,我無法重現,因此不能調試。它每天發生超過200次,所以我猜這是相當嚴重的。調試objc_msg發送崩潰我無法重現

我讀過一些關於NSZombie的內容,但是我無法重現崩潰,所以我猜測它沒用。 這裏是一個崩潰報告:

SIGSEGV 
0 libobjc.A.dylib 0x3aa515b0 objc_msgSend + 15 
1 UIKit 0x34d493df + 294 
2 UIKit 0x34cae469 + 52 
3 QuartzCore 0x34926099 + 160 
4 QuartzCore 0x34925ff1 + 64 
5 IOMobileFramebuffer 0x36ba1fd7 + 154 
6 IOKit 0x33920449 IODispatchCalloutFromCFMessage + 192 
7 CoreFoundation 0x32d035db + 118 
8 CoreFoundation 0x32d0e173 + 34 
9 CoreFoundation 0x32d0e117 + 138 
10 CoreFoundation 0x32d0cf99 + 1384 
11 CoreFoundation 0x32c7febd CFRunLoopRunSpecific + 356 
12 CoreFoundation 0x32c7fd49 CFRunLoopRunInMode + 104 
13 GraphicsServices 0x368562eb GSEventRunModal + 74 
14 UIKit 0x34b95301 UIApplicationMain + 1120 
15 My Bet main (main.m:16) Live 0x000705e7 0x6d000 + 13799 

他們相信問題可以在UIAlertView中一些類似的主題,所以這裏是我如何使用它們的例子:在file.h

UIAlertView *alertView; 

in file.m

-(void)wait{ 
UIActivityIndicatorView * activityView = [[UIActivityIndicatorView alloc]initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleWhiteLarge]; 
activityView.frame = CGRectMake(121.0f, 50.0f, 37.0f, 37.0f); 
[activityView startAnimating]; 
alertView = [[UIAlertView alloc] initWithTitle:NSLocalizedString(@"Searching...", @"") message:nil delegate:nil cancelButtonTitle:nil otherButtonTitles:nil]; 
[alertView addSubview:activityView]; 
[alertView show]; 
[NSThread detachNewThreadSelector:@selector(function) toTarget:self withObject:nil]; 
} 
-(void)function{ 
// Do some web request 
[alertView dismissWithClickedButtonIndex:0 animated:NO]; 
if(response == nil){ 
    UIAlertView *alert = [[UIAlertView alloc] initWithTitle:NSLocalizedString(@"Timeout", @"") message:NSLocalizedString(@"Connection timeout", @"") delegate:nil cancelButtonTitle:NSLocalizedString(@"Close", @"") otherButtonTitles:nil ]; 
    [alert show]; 
} 
} 

任何提示我如何可以繼續解決這個問題? 謝謝

回答

2

可能是崩潰是由於解僱和顯示UIAlertView從其他線程。

絕不會在其他線程中執行UI任務。主線程應該完成UI任務。

變化function像:

-(void)function 
{ 
// Do some web request 

dispatch_async(dispatch_get_main_queue(), ^{ 
    [alertView dismissWithClickedButtonIndex:0 animated:NO]; 
    if(response == nil) 
    { 
     UIAlertView *alert = [[UIAlertView alloc] initWithTitle:NSLocalizedString(@"Timeout", @"") message:NSLocalizedString(@"Connection timeout", @"") delegate:nil cancelButtonTitle:NSLocalizedString(@"Close", @"") otherButtonTitles:nil ]; 
    [alert show]; 
    } 
    }); 
} 
+0

是它做dispatch_async相同的(dispatch_get_main_queue(),^ {[alertView dismissWithClickedButtonIndex:0動畫:NO];});然後使用另一個dispatch_async顯示第二個警報? – lorenzop 2013-04-29 14:18:51

+0

@ user1187692:P不需要這樣做:)您已經在主線程中使用'dispatch_get_main_queue',那麼不需要再次使用GCD和'dispatch_get_main_queue'。您可以將這些行寫入一個'dispatch_get_main_queue' GCD。 – 2013-04-30 04:00:58