【Objective-c】 性能优化_TableView优化

UITableView 在移动开发中常常是必不可少的,并且是动态的加载,要很好的滚动显示效果,就必须更多的了解UITableView的实现机制,更好的优化。
UITableView的优化分两块:布局优化、渲染优化、异步操作。(也可以理解为平衡CPU和GPU的负载,这就要理解为什么会造成卡顿的原因了)

一、布局优化
布局优化包括:布局优化和高度优化
1、布局有两种方式,第一种是AutoLayout(storyboard、xib或Masonry),第二种是frame。使用AutoLayout布局的话可以省去人工计算成本和灵活多变,相对的就会增加CPU的负载,而使用frame对CPU来说就很简单,唯一的缺点就是可扩展性差。以下是引用Draveness的一张图,展示两种布局的性能差别

Paste_Image.png

补充:
(1)在开发的过程中,本人会优先考虑使用AutoLayout的方式,原因有两个:第一,AutoLayout布局容易且快,在开发中优先考虑就是完成功能;第二是现在的手机硬件越来越好,性能堪比电脑,如果不是特别复制的界面一般TableView滑动的流畅度都是没问题的。
(2)Frame布局方式,这里特别推荐Yang2333的文章,他的实现方式挺新颖的,并且对于tableView的优化方式也是信息量满满的

2、高度优化
UITableView是UIScrollView的子类,所以也是要计算其ContentSize,UITableView的contentSize的高度是全部Cell的高度和。设置UITableView的高度有两种方式
第一种是直接设置tableView的属性rowHeight(这种方式只适合设置固定高度的Cell,并且也是设置固定高度的推荐方式);
第二种是通过代理方法
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath.
因为UITableView 实现机制的原因,每显示一个Cell都需要执行N次这个方法(并且包括显示在屏幕或还没显示的),如果在这个方法中添加计算Cell的复杂算法,可想而知这对CPU而言是非常重的负担。优化的方向是怎么获取Cell的高度并减少计算的难度。
本人的做法:关于UITableView布局的优化,一直都是在使用Masonry和UITableView+FDTemplateLayoutCell两个框架,对于一般的项目来说都是没什么问题的。
UITableView+FDTemplateLayoutCell优化原理

补充:
对于不是固定高度的Cell,这里还有一个小技巧,对提高UITableView的流畅度很有帮助的。
在tableView:cellForRowAtIndexPath: 方法中需要为每一个Cell 调用一次,它应该快速执行,要尽可能块的返回重用Cell实例。Cell还没显示到屏幕上,不再这里执行数据绑定
tableView:willDisplayCell:forRowAtIndexPath: 在Cell要显示时调用,在这里执行数据绑定

补充设置圆角的正确姿势:bestswifter


二、渲染优化
讲渲染优化这里有几个概念需要先提的:混合操作、离屏渲染,像素对齐。
混合操作
渲染最慢的操作之一,是由GPU完成,我们的目的就是减少混合操作的次数。
查看混合操作的方式如下图

Paste_Image.png
Paste_Image.png

离屏渲染
iOS-离屏渲染详解
离屏渲染优化详解:实例示范+性能测试
关于离屏渲染上面两篇文章已经写得很详细了,这里再推荐一种查看离屏渲染的调试技巧,如下图

Paste_Image.png
Paste_Image.png

像素对齐
有了Retain屏后,CocoTouch环境下,可以使用屏幕点来取代像素了,并且屏幕点可以是浮点值,
当屏幕点是浮点数时,iOS 将会执行子像素渲染,这技术在特定类型的内容(如文本)时很有意义,但是当绘制
平滑直线时则没有必要了,这会让iOS 执行一些不必要的任务,从而降低FPS
查看方式:在iOS模拟器上运行程序,在”Debug“菜单中选中”Color Misaligned Image“。
有两种高亮区域:品红色区域会执行子像素渲染,而黄色区域是图片大小没有对齐的情况。
建议:对所有像素相关的数据做四舍五入处理,包括点坐标,UIView的高度和宽度。
跟踪你的图像资源:图片必须是像素完美的,否则在Retina屏幕上渲染时,它会做不必要的抗锯齿处理。

还有一个是opaque值,opaque是一个渲染性能的开关标识符,并不代表视图的透明度(aphal 才是视图的透明度属性值),opaque默认值是YES,如果opaque的值为NO,则是合成渲染,加大了GPU合成计算视图显示的计算难度。

第三:异步操作
异步操作主要是为了尽快返回Cell,通常是异步操作读写数据库和网络请求。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容