面试聊iOS:性能优化

大家好,我是面试聊iOS的程序员。
这篇文章将和大家分享面试iOS时聊RunLoop一般都可以聊些什么。

抖音搜索 面试聊iOS 观看视频版


相关文章链接
面试聊iOS:内存管理
面试聊iOS:RunTime(一)
面试聊iOS:RunTime(二)
面试聊iOS:Block
面试聊iOS:多线程
面试聊iOS:RunLoop
面试聊iOS:性能优化


卡顿优化

屏幕成像过程:CPU计算数据->GPU进行渲染->屏幕发出Vsync信号->成像。
假如屏幕已经发出了Vsync信号,但是GPU还没有渲染完成,则只能将上一次的数据显示出来,以致于当前计算的帧数据丢失,这样就产生了卡顿,当前计算好的帧数据只能等待下一个周期去渲染。

解决卡顿的主要思路就是尽可能的减少CPU与GPU资源的消耗
按照60fps的刷帧率,每隔16ms就会有一次Vsync信号

优化思路

针对CPU
  • 尽量用轻量级的对象,如:不用处理事件的UI控件可以考虑使用CALayer
  • 不要频繁的调用UIView的相关属性,如:frame、bounds、transfor等
  • 尽量提前计算好布局,在有需要的时候一次性调整对应属性,不要多次修改
  • AutoLayout会比直接设置frame消耗更多的CPU资源
  • 图片size和UIImageView的size保持一致
  • 控制线程的最大并发数
  • 耗时操作放入子线程,如:文本的尺寸计算、绘制,图片的解码、绘制等
针对GPU
  • 尽量避免短时间内显示大量的图片
  • GPU能处理的尺寸最大纹理尺寸为4096*4096,超过这个尺寸就会占用CPU资源,所以纹理不能超过这个尺寸
  • 尽量减少透明视图的数量与层次
  • 减少透明的视图(alpha<1),不透明就设置opaque为YES视
  • 尽量避免离屏渲染,以下操作会导致离屏渲染:
    1. 光栅化,layer.shouldRasterize = YES
    2. layer.mask
    3. layer.maskToBounds = YES, layer.cornerRadius > 0
    4. 阴影未设置layer.shadowPath

耗电优化

耗电主要来源

1、CPU处理
2、网络请求
3、定位
4、图像渲染

优化思路:

  • 尽可能降低CPU、GPU功耗
  • 少用定时器
  • 定位优化
    1. 如果只是需要快速确定用户位置,用CLLocationManager的requestLocation方法定位,定位硬件会自动断电
    2. 若不是导航应用,尽量不要实时更新位置,定位结束就关掉定位服务�尽量降低定位精度,如不使用精度最高的KCLLocationAccuracyBest
    3. 需要后台定位时,尽量设置pauseLocationUpdatesAutomatically为YES,若用户不怎么移动的时候,系统会自动暂停位置更新

启动优化

热启动

app进程还在系统中,无需开启新进程的启动过程

冷启动

app不在系统进程中,用户再点击启动app的过程,这时需要创建一个新进程分配给app。

app启动最佳速度是400ms内,因为从点击app图标启动,然后Launch Screen出现再消失的时间就是400ms。
app启动最慢不能>20s,否则app进程会被系统杀死。

冷启动的整个过程是指从用户唤起app开始到AppDelegate中的didFinishLaunchWithOptions方法执行完毕,并以执行main()函数的时机为分界点,分为pre-main和main()阶段。

Mach-O

Mach Object File Format:是一种用于记录可执行文件、共享库、动态加载代码和内存转储的文件格式。是OSX和iOS上主要的可执行文件格式,类似于Windows系统上的exe。
app编译生成的二进制可执行文件就是Mach-O格式的,iOS工程所有的类编译后会生成对应的目标文件.o文件,而这个可执行文件就是这些.o文件的集合。

.ipa(iPhone Application),实际上只是一种变相的zip压缩包。

dylib:动态库,是运行时加载的,可以被多个app进程共用。分为系统dylib和内嵌dylib(即开发者手动引入的动态库)
dyld:动态链接器,一个专门用来加载dylib的库
dyld shared cache:动态库共享缓存,当需要加载的动态库非常多时,相互依赖的符号也更多了,为了节省解析处理符号的时间,OSX和iOS上动态链接器使用了共享缓存。
images:镜像,每个app都是以images为单位进行加载的。
executable:应用的二进制可执行文件
dylib:动态链接库
bundle:资源文件,属于不能被链接的dylib,只能在运行时通过dlopen()加载
framework:可以是动态库,也可以是静态库,是一个包含dylib、bundle和头文件的文件夹。

冷启动优化

pre-main阶段

重新梳理架构,减少不必要的内置动态库数量
进行代码瘦身,合并或删除无效的ObjC类、category、selector、c++静态全局变量等(可以借助AppCode的Inspect Code功能进行代码瘦身)
将不必须在+laod方法中实行的任务延迟到+initialize中
减少c++虚函数
swift开发尽量使用struct

main()阶段

耗时操作尽量延迟执行,不要全都放到didFinishedWithOptions方法中执行
在release包中移除NSLog打印

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

推荐阅读更多精彩内容