UITableView-01基本使用
UITableView-02模型优化
UITableView-03复杂的Plist解析
UITableView-04常见属性和样式
UITableViewController-01简单使用
- 为什么需要性能优化?
-
UIScrollView
的一个特点,可以在有限的界面,放置无限的内容!
UITableView
继承UIScrollVIew
,所以也拥有此特点. - 苹果的
UITableViewCell
做到了懒加载.
不会一次性将所有内容,都加载到手机界面!而是,根据展示界面的大小来确定,加载多少内容! - 苹果采取的方法,很销毁内存和性能!
当已经创建好的cell, 移除界面时,会被销毁!
往回拉时,又再次创建新的cell.(可是内容根本没有改变,完全没必要,再创建新的)
-
- 优化的思路
- 把滑出视野范围内,看不见的cell,放入缓存池!(不是销毁)
- 滑动tableView,当需要添加cell的时候
- 先去缓存池看,有没有cell
- 有cell则添加到tableview上,修改cell的数据
(注意是修改数据,不是重新创建新的cell)
-
创建cell的时候要有标识.
因为缓存池中可能有多个cell,cell之间的高度和样式,可能不一样.
使用性能优化的方式,创建多行的tableView
.
-
dequeueReusableCellWithIdentifier
-缓冲池查找cell -
initWithStyle:UITableViewCellStyleDefault reuseIdentifier:
-创建新的cell,且设置重用的ID.
//每组多少行
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
return 200;
}
//每行显示内容
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
//cell的标识
static NSString *ID = @"wine";
//根据ID去缓冲池找对应的cell
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
//缓冲池里面没有对应cell,也就是cell == nil;
if(cell == nil){
//创建cell,并设置重用ID
cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:ID];
//打印出来的新地址,远远小于200,说明cell不是一次性创建
NSLog(@"cell的新地址%p",cell);
}
cell.textLabel.text = [NSString stringWithFormat:@"当前行是第%zd行",indexPath.row];
if (indexPath.row % 2) { //偶数行
cell.accessoryType = UITableViewCellAccessoryCheckmark;
}else{
cell.accessoryType = UITableViewCellAccessoryDisclosureIndicator;
}
//当滑动tableView时,同一地址被多少打印.
//说明cell被重复使用,达到优化性能的目的
NSLog(@"第%zd行,cell地址%p",indexPath.row,cell);
return cell;
}