iOS 面试全方位剖析 -- UI视图篇(二)


  • UITableView相关
  • 事件传递&视图响应
  • 图像显示原理 (一)
  • 卡顿&掉帧
  • 绘制原理&异步绘制
  • 离屏渲染
  • 面试问题总结 (二)

图像显示原理

具体的看一下CPU和GPU做了哪些事,看下图


CPU工作

  • UI布局
  • 文本计算
  • 绘制,比如 drawRect 方法
  • 图片编解码
  • 提交位图

GPU 渲染管线

  • 纹理渲染
  • 视图混合

卡顿&掉帧

UI卡顿,掉帧的原因


一般页面滑动的流畅性是60fps,每秒会有60帧的画面更新,也就是每16.7ms需要产生一帧画面,这过程需要GPU,CPU协同产生一帧数据。

如下,比如 CPU 花费时间绘图解码之后将位图交给 GPU 合成渲染,准备下一个VSync信号的到来。
第二段,当 CPU 解码,计算时间过长的时候,留给GPU渲染的时间就很少,所以 GPU 需要合成渲染全部准备完毕需要的时间可能就要超过 16.7ms,在下一帧VSync信号到来的时候没有准备这一帧画面,所以就会产生掉帧.


UITableView 的滑动优化方案

了解以上内容之后,问题来了,对于 UITableView 有哪些优化方案?
我们就可以基于 GPU 和 CPU 这俩方面来进行解答

CPU
  • 对象创建,调整,销毁
  • 预排版(布局计算,文本计算)
  • 预渲染(文本异步绘制(下面会提到),图片编解码等)
    像对象创建,布局计算等都可以放到子线程去做,主线程可以有更多的时间去响应用户的交互
GPU
  • 纹理渲染
    比如一些圆角和阴影的设置,容易触发离屏渲染,导致GPU工作量非常大, 这是一个优化点.尽量避免离屏渲染,减轻GPU的压力。详细在后一个点专门讲一下

  • 视图混合
    当有多个视图层层叠加,视图合成,每一个像素的合成对应的像素值,需要进行大量的计算。可以在一定程度上减轻图层的复杂度, 通过CPU层面的异步绘制机制,达到提交的位图本身是一个层级少的视图.
    具体事例可以看一下这里

进一步,了解一下UI的绘制原理


绘制原理&异步绘制

绘制原理

通过一幅图看一下UIView的视图绘制原理

在调用UIView setNeesDisplay 并不会立刻发生对应视图的对应工作,实际上是到当前 Runloop 快要结束的时候([CALayer display])才会开始介入到UI视图的绘制当中, 如果不响应 displayLayer 代理方法的时候就会走系统绘制流程,如果响应这个方法,就会走异步绘制的入口,这样就给我们异步绘制留有了一个余地.

我们看一下系统绘制的流程图



在 drawRect之前会调用 drawLayer, 举个例子,可以更方便看到系统的调用过程

- (void)drawRect:(CGRect)rect {
    CGContextRef con = UIGraphicsGetCurrentContext();
    CGContextAddEllipseInRect(con, CGRectMake(0,0,100,200));
    CGContextSetRGBFillColor(con, 0, 0, 1, 1);
    CGContextFillPath(con);
}

此时的堆栈


一目了然了吧

那么怎么实现异步绘制呢?

异步绘制

看图说话


这里看看在全局队列子线程里做的工作, 首先通过CGBitmapContextCreate()创建一个位图的上下文,然后通过CoreGraphic API 做一些UI控件的绘制工作,之后再通过CGBitmapContextCreateImage()生成CGImage图片,再回到主队列
提交位图。到这里就完成了一个UI控件的异步绘制。

到这里,应该能够了解了UI视图绘制的机制和原理,具体的示例和使用还需要自己查找和多了解下第三方的内部实现.


离屏渲染

什么是离屏渲染?你有什么理解? 何时会触发?

有离屏,自然也有在屏渲染,看一下概念


何时会触发?

  • 圆角(和 maskToBounds一起使用)
  • 图层蒙版
  • 阴影
  • 光栅化

为什么要避免离屏渲染?
第一个问题,在触发离屏渲染的时候,会增加GPU的工作量,导致掉帧卡顿的情况,具体回顾上文。 UIKit性能调优实战讲解


面试问题总结

  • 系统的UI事件传递机制是怎么样的 ?
  • 使UITableView滚动更流畅的方案或思路都有哪些 ?
  • 什么是离屏渲染 ? (位于GPU层面) ?
  • UIView和CALayer之间的关系是怎样的 ?

如果看着题还是一脸迷茫,建议回过头再看看理解一下.

视图篇的到此为止了,接下来是 Objective-C语言特性相关面试问题


转载请标明出处

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

推荐阅读更多精彩内容