8

我试过搜索这个,但没有运气,所以希望有一些大师可能知道答案。

我在 iTunes Connect 中看到我的应用程序因特定堆栈跟踪而崩溃的大量报告,但堆栈跟踪显示没有任何用处。

#0. Crashed: main
0  UIKit                          0x1871100c0 __56-[UIPresentationController runTransitionForCurrentState]_block_invoke + 324
1  UIKit                          0x1871100bc __56-[UIPresentationController runTransitionForCurrentState]_block_invoke + 320
2  UIKit                          0x1870630c8 _runAfterCACommitDeferredBlocks + 292
3  UIKit                          0x187070a80 _cleanUpAfterCAFlushAndRunDeferredBlocks + 92
4  UIKit                          0x186da25a4 _afterCACommitHandler + 96
5  CoreFoundation                 0x181c0c728 __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 32
6  CoreFoundation                 0x181c0a4cc __CFRunLoopDoObservers + 372
7  CoreFoundation                 0x181c0a8fc __CFRunLoopRun + 928
8  CoreFoundation                 0x181b34c50 CFRunLoopRunSpecific + 384
9  GraphicsServices               0x18341c088 GSEventRunModal + 180
10 UIKit                          0x186e1a088 UIApplicationMain + 204
11 MyApp                          0x100082e6c main (main.m:19)
12 libdyld.dylib                  0x1816d28b8 start + 4

报告没有模式,发生在 iOS 9.1、9.2、9.3-10 和各种 iPhone 和 iPad 上,也没有任何线索可以帮助重现它。

有没有人经历过这样的事情,并对可能导致它的原因有所了解/怀疑?

4

1 回答 1

10

我有完全相同的崩溃,我已经找到了原因。我的代码的高度简化版本看起来像

[self dismissViewControllerAnimated:YES completion:nil];
// call a method that ends up doing
[appRootViewController dismissViewControllerAnimated:NO completion:nil];

self在上面的代码片段中是一个视图控制器,它以模态方式呈现在根上。视图控制器本身也在当前上下文中模态地呈现了一些其他控制器。所以我正在做的是尝试用动画解除那个过电流上下文控制器,然后调用其他代码最终从根目录解除任何呈现的视图控制器而不用动画。

或者换一种说法,为我刚刚启动的动画关闭提供当前上下文的视图控制器会从视图层次结构中删除,而之前的动画关闭正在进行中。

在 Xcode 中重现此内容时,它还会将以下内容记录到控制台:

transitionViewForCurrentTransition 未设置,演示控制器在演示期间被关闭?(<_UIOverCurrentContextPresentationController: 0x7faf277d9c30>)

于 2016-09-16T21:08:14.777 回答