UITableViewRowData,numberOfSectionsInTableView

时间:2011-05-29 01:04:09

标签: uitableview

我试图理解为什么每次更新数据源时都会多次调用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的原因是另一个原因,但我想首先理解这些。

1 个答案:

答案 0 :(得分:1)

您的表numberOfSectionsInTableView被多次调用,因为您正在重新加载表数据。每当您重新加载表时,此方法将检查tableview的所有委托。