在启动时,我已将应用程序设置为从Firebase检索数据,创建对象并将它们添加到数组中,然后将它们添加到UITableView中。即使每个对象都是单独创建的,但项目都是创建的,但直到创建数据中的每个对象后,才将其添加到UITableView中。
Firebase在主线程上运行,因此这不是GCD问题。我在viewDidLoad中运行retrieveData()。
似乎这些项目已放入内存中(未添加到tableview中吗?),并继续堆积直到创建所有项目。届时,所有内容都将加载到表视图中,并且内存使用率恢复正常。如果有足够的项目,这将导致极高的内存使用率并导致崩溃。
func retrieveData(){
let dateString = getDate()
ref = Database.database().reference()
ref.child("orders/").child(Auth.auth().currentUser!.uid).child(dateString).child("products").observeSingleEvent(of: .value, with: { (snapshot) in
let value = snapshot.value as? NSDictionary
if (value != nil){
for (key) in value! {
let item = key.value as? [String:Any]
let (barcode, name, _, bottleSize) = self.getInfo(code: item!["code"]! as! String)
self.generateItem(barcode: barcode, name: name, bottleSize: bottleSize, quantity: item!["quantity"]! as! String, isInitial: true)
}
}
}) { (error) in
print(error.localizedDescription)
}
}
func generateItem(barcode: String, name: String, bottleSize: String, quantity: String, isInitial: Bool = false) {
let i = item(code: barcode, name: name, size: bottleSize, quantity: quantity)
order.append(i)
print("Item Created --- ", order[order.count - 1].name,order[order.count - 1].quantity,order[order.count - 1].code)
let indexPath = IndexPath(row: order.count - 1, section: 0)
orderTableView.beginUpdates()
orderTableView.insertRows(at: [indexPath], with: .automatic)
orderTableView.endUpdates()
// Update Firebase database
if (isInitial == false){
updateDatabase()
}
}
最佳答案
首先尝试构造item
对象并追加到数组,然后直接调用reloadData()
。看看它怎么运作。
let value = snapshot.value as? NSDictionary
if (value != nil){
for (key) in value! {
let item = key.value as? [String:Any]
let (barcode, name, _, bottleSize) = self.getInfo(code: item!["code"]! as! String)
let i = item(code: barcode, name: name, size: bottleSize, quantity: quantity)
order.append(i)
}
orderTableView.reloadData()
}