崩溃呈现模态视图控制器

时间:2011-02-04 10:44:06

标签: iphone cocoa-touch ios4 crash modalviewcontroller

我遇到了这个崩溃。它类似于其他线程,但不一样。 我想先显示一个模态视图控制器,用户转到特定的视图控制器。按照提示,我这样做 - (void)viewDidAppear:(BOOL)动画,并按照我的推荐应用延迟。

 - (void) viewDidAppear:(BOOL)animated 
    {
      [super viewDidAppear:animated];
       [self performSelector:@selector(presentMyModal) withObject:nil afterDelay:1];
    }



     - (void) presentModal{
    ModalViewController *modal = [[[ModalViewController alloc] init] autorelease];
    [self presentModalViewController:modal animated:YES];   
   }

之后,ramdomly它崩溃了。我在控制台中收到此消息:

<Warning>: *** Assertion failure in -[UIWindowController transition:fromViewController:toViewController:target:didEndSelector:], /SourceCache/UIKit/UIKit-1447.6.4/UIWindowController.m:186
Thu Feb  3 10:00:44 unknown MyApp[1830] <Error>: *** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'Attempting to begin a modal transition from <UINavigationController: 0x454260> to <ModalViewController: 0x47af00> while a transition is already in progress. Wait for viewDidAppear/viewDidDisappear to know the current transition has completed'
    *** Call stack at first throw:
    (
        0   CoreFoundation                      0x3759dc7b __exceptionPreprocess + 114
        1   libobjc.A.dylib                     0x32d9bee8 objc_exception_throw + 40
        2   CoreFoundation                      0x3759dac3 +[NSException raise:format:arguments:] + 70
        3   Foundation                          0x351a3e73 -[NSAssertionHandler handleFailureInMethod:object:file:lineNumber:description:] + 62
        4   UIKit                               0x359e92a8 -[UIWindowController transition:fromViewController:toViewController:target:didEndSelector:] + 208
        5   UIKit                               0x359e8c98 -[UIViewController presentModalViewController:withTransition:] + 2792
        6   UIKit                               0x35a7b51c -[UIViewController _tryRecursivelyPresentModalViewController:withTransition:] + 116
        7   UIKit                               0x359e84c0 -[UIViewController presentModalViewController:withTransition:] + 784
        8   UIKit                               0x359e8060 -[UIViewController presentModalViewController:animated:] + 96
        9   MyApp                         0x0005d57f -[MyAppViewController presentMyModal] + 58
        10  Foundation                          0x351724db __NSFireDelayedPerform + 366
        11  CoreFoundation                      0x37552305 __CFRUNLOOP_IS_CALLING_OUT_TO_A_TIMER_CALLBACK_FUNCTION__ + 16
        12  CoreFoundation                      0x37551cd9 __CFRunLoopDoTimer + 988
        13  CoreFoundation                      0x37521a91 __CFRunLoopRun + 1184
        14  CoreFoundation                      0x3752150b CFRunLoopRunSpecific + 226
        15  CoreFoundation                      0x37521419 CFRunLoopRunInMode + 60
        16  GraphicsServices                    0x33e76d24 GSEventRunModal + 196
        17  UIKit                               0x3591d57c -[UIApplication _run] + 588
        18  UIKit                               0x3591a558 UIApplicationMain + 972
        19  MyApp                         0x0000e75f main + 50
        20  MyApp                         0x0000e6e8 start + 52

如您所见,我等到视图出现。这可能是操作系统错误吗?它似乎试图递归其他模态视图控制器,引发崩溃。 非常感谢。

2 个答案:

答案 0 :(得分:0)

除了我在评论中挑剔,我想我也可以帮助这个。我认为你需要在其他地方寻找罪魁祸首。我用这个片段创建了一个新项目和一个视图控制器:

#import "VC1.h"


@implementation VC1

- (void) viewDidAppear:(BOOL)animated {
  [super viewDidAppear:animated];
  [self performSelector:@selector(presentModal) withObject:nil afterDelay:1.0];
}

- (void)presentModal {
  static int colorChooser = 0;
  VC1 *vc1 = [[[VC1 alloc] init] autorelease];
  switch (colorChooser%2) {
    case 0:
      vc1.view.backgroundColor = [UIColor whiteColor];
      break;
    default:
      vc1.view.backgroundColor = [UIColor blackColor];
      break;
  }
  colorChooser++;
  [self presentModalViewController:vc1 animated:YES];
}

@end

按下导航控制器后,它完美无瑕。它在黑白视图之间递归交替,在SIM卡和3G设备上进行测试。

由于某些通知或其他异步方式,您可能正在进行其他视图转换?无论哪种方式,您都需要为任何人分享更多代码,以告知问题所在。

答案 1 :(得分:0)

我们首选的解决方案是使用 - [UIViewController presentViewController:animated:completion:]并在完成块中执行下一个操作(例如,呈现另一个VC)。

例如:

[self presentViewController:yourViewController animated:YES completion:^{
    [yourViewController presentMyModal];
}];

此方法是在iOS 5.0中引入的。