iOS开发UITableView篇:[self.tableView reloadData]执行时间过长问题解决历程

TableView数据刷新非常慢问题

出现问题原因:

  1. 网络问题?
  2. 处理数据时间过长?
  3. Cell赋值时有耗时操作?

分析

  1. 网络问题排除
    • 通过打印,数据请求已经完毕
  2. 处理数据时间过长问题排除
    • 处理前打印时间戳,处理完成后打印时间戳,然而并没有耗时
  3. 定位在Cell代理方法里面问题
    • 定位理由:
      NSLog(@"开始刷新%d", time(0));
      [self.tableView reloadData];
      NSLog(@"刷新结束%d", time(0));

      • 开始刷新–》结束刷新 随着数据源数组的count增多,这句代码的间隔增大 (400条数据,间隔达到了4秒)

问题解决

  1. cell赋值方法
    • 经过打印,执行时间基本无耗时
  2. cell计算高度方法
    • 使用了动态高度的方法,延迟定位在这里
    • Google查找“fd_heightForCellWithIdentifier 方法耗时”问题
      确定是这个方法的问题
      • 借用别人的回答:
      • 如果用 cacheByKey API,已经可以保证没有重复计算;若使用 cacheByIndexPath API,要注意直接调用 - reloadData 会导致所有高度缓存重新计算,- fd_reloadDataWithoutInvalidateIndexPathHeightCache 才不会。因为 UIKit 的方法只能在主线程调用,所以当 Cell 约束复杂,或者里面有很多 AttributedString 时,无论如何都会卡主线程。另一个 Tip 就是在 configure cell 时,根据 cell.fd_isTemplateLayoutCell 来区分算高 cell 和真实 cell,避免不必要的副作用引起的卡顿。接下来我也会着手去优化 TemplateCell 引发的性能问题。

结果

更换计算高度方法后问题解决。
附上链接:https://github.com/forkingdog/UITableView-FDTemplateLayoutCell/issues/116

你可能感兴趣的:(iOS开发,小技巧,Bug)