我试图理解为什么每次更新数据源时都会多次调用numberOfSectionsInTableView。从gdb中的堆栈跟踪,我看到以下
#0 -[JobPickerTVC numberOfSectionsInTableView:] (self=0x4d61fe0, _cmd=0x6207f5, tableView=0x6034800) at JobPickerTVC.m:153
#1 0x003d66ff in -[UITableViewRowData(UITableViewRowDataPrivate) _updateNumSections] ()
#2 0x003d63b0 in -[UITableViewRowData invalidateAllSections] ()
#3 0x00299010 in -[UITableView(_UITableViewPrivate) _endCellAnimationsWithContext:] ()
#4 0x002891e8 in -[UITableView endUpdates] ()
#5 0x000050c8 in -[JobPickerTVC controllerDidChangeContent:] (self=0x4d61fe0, _cmd=0x17109d, controller=0x4da5e40) at JobPickerTVC.m:442
接着是
#0 -[JobPickerTVC numberOfSectionsInTableView:] (self=0x4d61fe0, _cmd=0x6207f5, tableView=0x6034800) at JobPickerTVC.m:153
#1 0x003d66ff in -[UITableViewRowData(UITableViewRowDataPrivate) _updateNumSections] ()
#2 0x003d6417 in -[UITableViewRowData ensureAllSectionsAreValid] ()
#3 0x0029902e in -[UITableView(_UITableViewPrivate) _endCellAnimationsWithContext:] ()
#4 0x002891e8 in -[UITableView endUpdates] ()
#5 0x000050c8 in -[JobPickerTVC controllerDidChangeContent:] (self=0x4d61fe0, _cmd=0x17109d, controller=0x4da5e40) at JobPickerTVC.m:442
据我所知,代码执行[UITableViewRowData invalidateAllSections ](第一条跟踪的第2行),然后是[UITableViewRowData ensureAllSectionsAreValid ](第2行)第二个痕迹)。这两个都通过调用[JobPickerTVC numberOfSectionsInTableView:]结束。因此,[JobPickerTVC numberOfSectionsInTableView:]被调用两次。我想知道为什么会发生这种情况以及这些操作正在做什么。
还有一个调用numberOfSectionsInTableView的原因是另一个原因,但我想首先理解这些。
答案 0 :(得分:1)
您的表numberOfSectionsInTableView被多次调用,因为您正在重新加载表数据。每当您重新加载表时,此方法将检查tableview的所有委托。