override func viewDidDisappear(_ animated: Bool) {
tableView.visibleCells.forEach {
if let cell = $0 as? PostsWithVideoCustom , let player = cell.player {
player.pause()
cell.player = nil
}
}
}
Я использую этот код на viewDidDisappear, и обычно это нормально.
Однако, если я performSegue на viewWillAppear
override func viewWillAppear(_ animated: Bool) {
if userDefaults.string(forKey: "goToEvent") != nil {
performSegue(withIdentifier: "postToEvent", sender: self)
}
}
У меня сбой на линии tableView.visibleCells.forEach
Как справиться с этим сбоем и что может его вызвать?
ОБНОВИТЬ
Этот сбой происходит только в том случае, если приложение запущено после того, как оно было убито, не происходит при выходе из фонового режима.
Крушение
Crashed: com.apple.main-thread
0 APP 0x104521cd4 specialized Posts.viewDidDisappear(_:) (Posts.swift:2127)
1 APP 0x104519864 @objc Posts.viewWillAppear(_:) + 4334082148
2 UIKitCore 0x247561684 -[UIViewController _setViewAppearState:isAnimating:] + 488
3 UIKitCore 0x247562008 -[UIViewController __viewDidDisappear:] + 144
4 UIKitCore 0x2474c31d8 -[UINavigationController viewDidDisappear:] + 232
5 UIKit 0x23b4b5ea8 -[UINavigationControllerAccessibility viewDidDisappear:] + 40
6 UIKitCore 0x247561684 -[UIViewController _setViewAppearState:isAnimating:] + 488
7 UIKitCore 0x247562008 -[UIViewController __viewDidDisappear:] + 144
8 UIKitCore 0x247498890 -[UITabBarController viewDidDisappear:] + 100
9 UIKitCore 0x247561684 -[UIViewController _setViewAppearState:isAnimating:] + 488
10 UIKitCore 0x247562008 -[UIViewController __viewDidDisappear:] + 144
11 UIKitCore 0x247564168 __64-[UIViewController viewDidMoveToWindow:shouldAppearOrDisappear:]_block_invoke.1383 + 44
12 UIKitCore 0x247562764 -[UIViewController _executeAfterAppearanceBlock] + 88
13 UIKitCore 0x247b10ef8 _runAfterCACommitDeferredBlocks + 564
14 UIKitCore 0x247aff93c _cleanUpAfterCAFlushAndRunDeferredBlocks + 352
15 UIKitCore 0x247b1e5a8 __34-[UIApplication _firstCommitBlock]_block_invoke_2 + 136
16 CoreFoundation 0x21b29ee68 __CFRUNLOOP_IS_CALLING_OUT_TO_A_BLOCK__ + 20
17 CoreFoundation 0x21b29e76c __CFRunLoopDoBlocks + 272
18 CoreFoundation 0x21b2997d0 __CFRunLoopRun + 1024
19 CoreFoundation 0x21b2990b0 CFRunLoopRunSpecific + 436
20 GraphicsServices 0x21d49979c GSEventRunModal + 104
21 UIKitCore 0x247b05978 UIApplicationMain + 212
22 APP 0x1044f8504 main (InboxInterests.swift:22)
23 libdyld.dylib 0x21ad5e8e0 start + 4
выложил полный краш
уверен, что этот фрагмент является причиной сбоя, что означает, что если вы прокомментировали его, он все равно вылетит или у вас есть другой контент?
Проверьте, правильно ли подключены розетки tableView.
@Sh_Khan Я сейчас проверяю это, я обновлю вопрос по результату
Что, если вы добавите вызовы super в начало обеих функций viewWillAppear и viewDidDisappear?
@AndréSlotta, ты думаешь, это изменит ситуацию?
Возможно. Стоит попробовать.
Этот сбой происходит только в том случае, если приложение запущено после того, как оно было убито, не происходит при выходе из фонового режима.
Какая именно строка вызывает сбой? Какое полное сообщение об ошибке?
@Sh_Khan да, если я прокомментирую эту строку, он не вылетит
@rmaddy tableView.visibleCells.forEach эта строка дает сбой, и вы можете найти отчет о сбое в вопросе
Я знаю, что отчет о сбое есть. Я спросил, что за сообщение об ошибке.





Я решил эту проблему, просто добавив
if tableView != nil {
}
Это было очень легко исправить. Но я думаю, что iOS должна в первую очередь управлять этим сама.
пост полный краш........