niOS設備的內存有限,如果用UITableView顯示成千上萬條數據,就需要成千上萬個UITableViewCell對象的話,那將會耗盡iOS設備的內存。要解決該問題,需要重用UITableViewCell對象
n
n重用原理:當滾動列表時,部分UITableViewCell會移出窗口,UITableView會將窗口外的UITableViewCell放入一個對象池中,等待重用。當UITableView要求dataSource返回UITableViewCell時,dataSource會先查看這個對象池,如果池中有未使用的UITableViewCell,dataSource會用新的數據配置這個UITableViewCell,然后返回給UITableView,重新顯示到窗口中,從而避免創建新對象
n
n還有一個非常重要的問題:有時候需要自定義UITableViewCell(用一個子類繼承UITableViewCell),而且每一行用的不一定是同一種UITableViewCell,所以一個UITableView可能擁有不同類型的UITableViewCell,對象池中也會有很多不同類型的UITableViewCell,那么UITableView在重用UITableViewCell時可能會得到錯誤類型的UITableViewCell
n
n解決方案:UITableViewCell有個NSString*reuseIdentifier屬性,可以在初始化UITableViewCell的時候傳入一個特定的字符串標識來設置reuseIdentifier(一般用UITableViewCell的類名)。當UITableView要求dataSource返回UITableViewCell時,先通過一個字符串標識到對象池中查找對應類型的UITableViewCell對象,如果有,就重用,如果沒有,就傳入這個字符串標識來初始化一個UITableViewCell對象
Cell的重用代碼
- (UITableViewCell*)tableView:(UITableView*)tableView cellForRowAtIndexPath:(NSIndexPath*)indexPath
{
// 1.定義一個cell的標識
staticNSString*ID =@”czcell";
// 2.從緩存池中取出cell
UITableViewCell*cell = [tableViewdequeueReusableCellWithIdentifier:ID];
// 3.如果緩存池中沒有cell
if(cell ==nil) {
cell = [[UITableViewCellalloc]initWithStyle:UITableViewCellStyleSubtitlereuseIdentifier:ID];
}
// 4.設置cell的屬性...
//內存中開辟空間,耗性能
// static修飾局部變量,可以保證局部變量值分配一次內存空間(只初始化一次)
//不使用宏,因為只有這一個方法里面要使用這個變量,不希望外部能夠使用到
staticNSString*cellId =@"hero";
// 1.首先通過@“A”標示符去緩存池里找有沒有可以循環利用的cell
UITableViewCell*cell = [tableViewdequeueReusableCellWithIdentifier:cellId];
// 2.如果找不到可以利用的cell,就創建
if(cell ==nil) {
cell = [[UITableViewCellalloc]initWithStyle:UITableViewCellStyleSubtitlereuseIdentifier:cellId];
}