我正在开发一个简单的 UIPageViewController,它有两个页面。每个页面都从不同的 ViewController 加载它们特定的 xib 文件,名为 PViewController 和 TViewController。
对于 PViewController,有三种不同的 View ,我们称它们为 A、B 和 C。当应用程序启动时,PViewController 成功出现,我可以向左滑动以查看 TViewController,同样没有问题。但是,当我在 PViewController 中并且作为对事件的响应时,我将当前 View A 更改为另一个 View B,然后向左滑动转到 TViewController,我收到以下异常并且应用程序终止:
*** Assertion failure in -[_UIQueuingScrollView _setWrappedViewAtIndex:withView:], /SourceCache/UIKit_Sim/UIKit-2935.137/_UIQueuingScrollView.m:338
2014-07-10 13:57:23.389 ***** [2012:60b] *** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'Unexpected subviews'
*** First throw call stack:
(
0 CoreFoundation 0x01fde1e4 __exceptionPreprocess + 180
1 libobjc.A.dylib 0x01c418e5 objc_exception_throw + 44
2 CoreFoundation 0x01fde048 +[NSException raise:format:arguments:] + 136
3 Foundation 0x018214de -[NSAssertionHandler handleFailureInMethod:object:file:lineNumber:description:] + 116
4 UIKit 0x00f3cc14 -[_UIQueuingScrollView _setWrappedViewAtIndex:withView:] + 261
5 UIKit 0x00f3d248 -[_UIQueuingScrollView _replaceViews:updatingContents:adjustContentInsets:animated:] + 812
6 UIKit 0x00f3d690 -[_UIQueuingScrollView _viewAtIndex:loadingIfNecessary:updatingContents:animated:] + 421
7 UIKit 0x00f40c65 __54-[_UIQueuingScrollView _didScrollWithAnimation:force:]_block_invoke + 110
8 UIKit 0x00f408de -[_UIQueuingScrollView _didScrollWithAnimation:force:] + 579
9 UIKit 0x00f3c452 -[_UIQueuingScrollView layoutSubviews] + 186
10 UIKit 0x00970964 -[UIView(CALayerDelegate) layoutSublayersOfLayer:] + 355
11 libobjc.A.dylib 0x01c5382b -[NSObject performSelector:withObject:] + 70
12 QuartzCore 0x04be445a -[CALayer layoutSublayers] + 148
13 QuartzCore 0x04bd8244 _ZN2CA5Layer16layout_if_neededEPNS_11TransactionE + 380
14 QuartzCore 0x04bd80b0 _ZN2CA5Layer28layout_and_display_if_neededEPNS_11TransactionE + 26
15 QuartzCore 0x04b3e7fa _ZN2CA7Context18commit_transactionEPNS_11TransactionE + 294
16 QuartzCore 0x04b3fb85 _ZN2CA11Transaction6commitEv + 393
17 QuartzCore 0x04b40258 _ZN2CA11Transaction17observer_callbackEP19__CFRunLoopObservermPv + 92
18 CoreFoundation 0x01fa636e __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 30
19 CoreFoundation 0x01fa62bf __CFRunLoopDoObservers + 399
20 CoreFoundation 0x01f839eb CFRunLoopRunSpecific + 491
21 CoreFoundation 0x01f837eb CFRunLoopRunInMode + 123
22 GraphicsServices 0x030285ee GSEventRunModal + 192
23 GraphicsServices 0x0302842b GSEventRun + 104
24 UIKit 0x00901f9b UIApplicationMain + 1225
25 ******* 0x000239fd main + 141
26 libdyld.dylib 0x02cc1701 start + 1
27 ??? 0x00000001 0x0 + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException
这是我为 UIPageViewController 实现的协议(protocol)方法:
- (UIViewController *)pageViewController:(UIPageViewController *)pageViewController viewControllerBeforeViewController:(UIViewController *)viewController
{
UIViewController *vc;
if(self.index==1) {
vc = (PViewController *)[[PViewController alloc] initWithNibName:@"PViewController" bundle:nil];
}
self.index--;
return vc;
}
- (UIViewController *)pageViewController:(UIPageViewController *)pageViewController viewControllerAfterViewController:(UIViewController *)viewController {
UIViewController *vc;
if(self.index==0)
vc = (TViewController *)[[TViewController alloc] initWithNibName:@"TViewController" bundle:nil];
self.index++;
return vc;
} //The exception occurs exactly when the app reaches this point.
这就是我在 View Controller 中切换 View 的方式,简单地说:
self.view = self.B;
问题:
我无法找出问题所在。我不知道在哪里捕获这个异常或者是什么导致了它?
最佳答案
我在使用启动时传递的以下参数时碰巧遇到了同样的错误:
-UIViewShowAlignmentRects YES
在浪费了 2 天时间试图在我的 UIPageViewController 中查找错误后,结果发现在禁用 XCode 生成的黄色矩形包装器后,NSInternalConsistencyException 消失了。
关于ios - UIPageViewController NSInternalInconsistencyException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24675000/