iOS8中屏幕旋转的问题

虽然iOS8将渐渐地无需再被兼容,但是解决问题是必须的。


最近在调试程序时,遇到以下问题:
*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '*** -[__NSPlaceholderArray initWithObjects:count:]: attempt to insert nil object from objects[0]'
很奇怪,只有iOS8的设备报了异常,说我尝试从空数组插入空数据。
全局断点定位在以下方法。

[self presentViewController:controller animated:YES completion:nil];

于是想方设法在附近找bug。一顿操作后发现,将以上代码中的controller是一个横屏的ViewController,而代码中的self中是一个竖屏的ViewController。在modal跳转的时候屏幕会发生旋转,接着就异常了。

为了证明我的观点,我尝试着把以下代码屏蔽,发现的确异常消失了。

- (BOOL)shouldAutorotate {
    return YES;
}

- (UIInterfaceOrientationMask) supportedInterfaceOrientations {
    return UIInterfaceOrientationMaskLandscape;
}

如果有人也遇到了这个问题,并读到了这里。然后各种搜索引擎“iOS8 屏幕旋转bug”。好巧,我们的方向都完全错了!

以上所有代码都没问题。也不是iOS8的系统bug。

问题其实是出在self或者self.parentViewController或者self.parentViewController.parentViewController……上。他们中某一个ViewController被多次modal。

被多次modal的方式可能是多次presentViewController,多次performSegueWithIdentifier,还有在storyboard上关联了按钮的跳转事件,又在点击事件里又写了一次跳转等等。

其实问题本来很简单,但是由于
1、iOS8以上的系统兼容了这个错误。并不会异常。
2、异常定位位置奇葩。
导致很容易误导开发者。

之前也有遇到其他的异常相信以后也不会避免,在此提醒一下自己:
1、不要轻易怀疑系统bug,99%的程序问题都是因为有问题的程序员。遇到问题应该首先定位自己的问题,不要先入为主认为是别人的问题,包括系统bug,后台bug,底层bug等。
2、调试方法。传统的打断点、写日志等方法虽然方便,但是遇到奇葩的问题往往事倍功半。屏蔽代码,写demo,更加有效但是相对麻烦。

你可能感兴趣的:(iOS8中屏幕旋转的问题)