У меня есть 2 простых представления (ViewController и TableviewController), из первого представления отображается второе представление. Во втором представлении (Tableview) отображается список массива. Когда я очень быстро удаляю строку в Tableview и сразу возвращаюсь назад (первое представление), приложение вылетает с ошибкой:
*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '*** -[__NSArrayM insertObject:atIndex:]: object cannot be nil'
*** First throw call stack:
(0x1d6bc7ef8 0x1d5d95a40 0x1d6b3d85c 0x1d6aace20 0x203afaa44 0x203acf4f8 0x203acf694 0x203aea3f4 0x203afa900 0x203c6ba34 0x203afa840 0x203af8dbc 0x20357a544 0x203580da4 0x2035811dc 0x203581e5c 0x20402c3c8 0x203c6ce68 0x203c42ee4 0x203c434d0 0x1db1bb394 0x104a84de4 0x104a92a94 0x1d6b561bc 0x1d6b51084 0x1d6b505b8 0x1d8dc4584 0x2035cb558 0x102452290 0x1d6610b94)
libc++abi.dylib: terminating with uncaught exception of type NSException
Мой код:
import UIKit
class TestTableViewController: UITableViewController {
var items = ["Apple", "Samsung", "Xiaomi", "Huawei", "Oppo", "Vivo"]
override func viewDidLoad() {
super.viewDidLoad()
}
// MARK: - Table view data source
override func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return items.count
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath)
cell.textLabel?.text = items[indexPath.row]
return cell
}
override func tableView(_ tableView: UITableView, canEditRowAt indexPath: IndexPath) -> Bool {
return true
}
override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
if editingStyle == .delete {
items.remove(at: indexPath.row)
tableView.deleteRows(at: [indexPath], with: .fade)
}
}
}
Но, если я удаляю строку и жду некоторое время (0,4-1 сек) или перезагружаю представление таблицы после удаления, сбоев не возникает.
override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
if editingStyle == .delete {
items.remove(at: indexPath.row)
tableView.reloadData() //After adding this line didn't handle any crashing
//tableView.deleteRows(at: [indexPath], with: .fade)
}
}
То же, что и @ Carpsen90, пока не могу воспроизвести ...
@ Carpsen90, вы должны удалить строку и очень быстро (между 0,1-0,6 сек) вернуться к предыдущему виду, лучше использовать реальное устройство, а не симулятор для его воспроизведения.
@AhmadF Я думаю, что эта проблема актуальна, потому что я проверял, что у некоторых приложений из App Store такая же проблема.
Я действительно использовал настоящее устройство. Что вы имеете в виду под "вернуться к предыдущему виду"? Вы имеете в виду отклонить текущий контроллер представления?
Мои версии: Xcode 10, swift 4, iOS 12, iPhone 8 plus
Даже при встраивании в контроллер навигации и быстром нажатии кнопки возврата. Возможно, у вас есть какие-то настройки на вашем телефоне, которые все портят.
@ Carpsen90 имеет два представления первого представления, встроенный контроллер навигации и добавляет простую кнопку для отображения второго представления таблицы. Из Tableview удалите строку и сразу нажмите кнопку «Назад» на контроллере навигации или проведите пальцем вправо, чтобы перейти к первому просмотру (стандартный жест смахивания).
@ Carpsen90, но когда я прокомментировал 'tableView.deleteRows (at: [indexPath], с: .fade)', сбой остановился.
Пытаться:
self.tableView.beginUpdates()
items.remove(at: indexPath.row)
tableView.deleteRows(at: [indexPath], with: .fade)
self.tableView.endUpdates()
Невозможно произвести эту ошибку. Поделитесь видео, с кодом проблем нет
Он вылетает, если вы удаляете строку с анимацией затухания и очень быстро щелкаете строку, в то время как другая строка удаляется, она выходит за пределы, но это не решает ее!
Я не могу воспроизвести это