如何修复“模型的消耗”? Swift 5运行时崩溃

时间:2019-04-26 20:10:22

标签: swift swift5

我刚刚将我的一个应用程序升级到了Swift 5,我并没有做太多改变,也似乎没有任何问题,所以我只是在生产中发布了它(幸运的是分阶段发布)。 1天后,我开始看到Crashlytics发生非常奇怪的崩溃,影响了使用我的应用的15%的用户。

这是堆栈跟踪:

Crashed: com.apple.main-thread
0  (Missing)                      0x31698aa1503e0 (Missing)
1  libswiftCore.dylib             0x1afa5ac68 _swift_release_dealloc + 28
2  App                            0x104194c3c outlined consume of MyModel? + 4300033084
3  App                            0x104482cb8 @objc MyController.__ivar_destroyer (<compiler-generated>)
4  libobjc.A.dylib                0x180f267cc object_cxxDestructFromClass(objc_object*, objc_class*) + 148
5  libobjc.A.dylib                0x180f366b8 objc_destructInstance + 68
6  libobjc.A.dylib                0x180f36720 object_dispose + 16
7  UIKitCore                      0x1ae2edac0 -[UIResponder dealloc] + 152
8  UIKitCore                      0x1add173e0 -[UIViewController dealloc] + 1748
9  App                            0x10431d82c BaseViewController.__deallocating_deinit (MyController.swift:56)
10 App                            0x10431d85c @objc BaseViewController.__deallocating_deinit (<compiler-generated>)
11 libobjc.A.dylib                0x180f41b9c (anonymous namespace)::AutoreleasePoolPage::pop(void*) + 672
12 CoreFoundation                 0x181d59f40 _CFAutoreleasePoolPop + 28
13 CoreFoundation                 0x181cd8e00 __CFRunLoopRun + 1932
14 CoreFoundation                 0x181cd8354 CFRunLoopRunSpecific + 436
15 GraphicsServices               0x183ed879c GSEventRunModal + 104
16 UIKitCore                      0x1ae2c3b68 UIApplicationMain + 212
17 App                            0x104108468 main (AppDelegate.swift:21)
18 libdyld.dylib                  0x18179e8e0 start + 4

我已经在网上搜索了一些内容,但是我发现Swift论坛上只有一个线程与此无关。

MyModel实际上是嵌套在另一个Model中的结构模型。 MyController是管理模型的非常庞大的控制器。

当弹出控制器并因此系统尝试取消分配所有相关属性时,崩溃似乎显然发生了。

我尝试了很多次都没有结果,而且我真的不知道从哪里开始寻找。

有人遇到了同样的问题吗?

更新[部分固定]: 看来这是广告框架引起的堆栈损坏,要解决此问题,我将MyModel从Struct移到了Class,现在放在了Heap上,无法进行两次释放。

1 个答案:

答案 0 :(得分:1)

根据我的经验,大多数outlined consume of错误是由并发问题引起的。当一个队列/线程读取该结构而另一队列/线程修改该结构却没有同步(互斥,信号量,屏障等)时。

您需要检查所有线程堆栈,以查看哪个线程同时与Main(崩溃的)线程访问MyModel