TableView数据刷新非常慢问题
出现问题原因:
- 网络问题?
- 处理数据时间过长?
- Cell赋值时有耗时操作?
分析
- 网络问题排除
- 通过打印,数据请求已经完毕
- 处理数据时间过长问题排除
- 处理前打印时间戳,处理完成后打印时间戳,然而并没有耗时
- 定位在Cell代理方法里面问题
- 定位理由:
NSLog(@"开始刷新%d", time(0));
[self.tableView reloadData];
NSLog(@"刷新结束%d", time(0));
- 开始刷新–》结束刷新 随着数据源数组的count增多,这句代码的间隔增大 (400条数据,间隔达到了4秒)
- 定位理由:
问题解决
- cell赋值方法
- 经过打印,执行时间基本无耗时
- 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