内容字号:默认大号超大号

段落设置:段首缩进取消段首缩进

字体设置:切换到微软雅黑切换到宋体

容易忽视的性能杀手:TableView刷新优化特例

2019-02-10 20:52 出处:清屏网 人气: 评论(0

TableView优化检查清单 一篇中,例出了TableView优化常见的一些入手点,本篇将给出一个在特定效果下,会影响TableView 刷新效率的一种情形及优化方法,在你决定用复杂方法优化TableView时,提前排除这种可能。

简单的文本也会导致低刷新率

本例中,cell将显示3000个数字:

TableView效果

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"KeyCell"];

    cell.textLabel.text = [NSString stringWithFormat:@"%ld", indexPath.row];
    cell.textLabel.backgroundColor = [UIColor clearColor];
    cell.textLabel.layer.shadowOffset = CGSizeMake(0, 2);
    cell.textLabel.layer.shadowOpacity = 0.5;
    return cell;
}

看上去是很简单的cell,下面用 Instruments 测一下FPS:

未优化前的FPS

出人意料地低, 平均没有超过40FPS

,是什么原因呢?

离屏渲染

打开“离屏渲染”标示:

离屏渲染检查

可见,透明背景+阴影引发了离屏渲染,去掉后FPS恢复正常,可是这样又达不到需要的阴影效果,有什么办法可以两全其美呢?

阴影也有高刷新率

我们可以做如下设置:

cell.layer.shouldRasterize = YES;

当shouldRasterize设成true时,将渲染 光栅化 ,即将layer渲染成一个bitmap,并缓存起来,等下次使用时直接使用缓存,不再重新去渲染,减少了GPU的占用。

由于bitmap是位图,在屏幕上就会有些失真,会看到毛刺比较明显:

开启光栅化后导致失真

需要设置比例值:

cell.layer.rasterizationScale = [UIScreen mainScreen].scale;

这样就可以即保证阴影的渲染效果,又保证了刷新率。

小提示

有些时候,发生问题的未必是复杂的数据,也有可能是系统机制的原因,因此先通过工具定位问题,再有针对性地进行优化,记住:

提前优化是万恶之源。

分享给小伙伴们:
本文标签: TableView

相关文章

发表评论愿您的每句评论,都能给大家的生活添色彩,带来共鸣,带来思索,带来快乐。

CopyRight © 2015-2016 QingPingShan.com , All Rights Reserved.

清屏网 版权所有 豫ICP备15026204号