App 启动动干了那些事情
- 一般情况下app 启动分为冷启动和热启动
** 冷启动是指,App点击启动前,他的进程不在系统里面,需要创建一个进程分配他的启动情况,这是一次完整的启动过程。
** 热启动是指,App 在冷启动用户将app退到后台,在app 的进程还在系统的情况下,用户点击log进入app的过程,这个过程做的事情非常少。
用户能感知到启动慢,其实都是发生在主线程上。而主线程慢的原因有很多,比如在主线程中进行了大量的读写操作、在渲染周期中执行了大量的计算等。
究竟如何才能把app启动的所有耗时都找出来呢?解决这个问题,你首先要弄清楚App在启动前都做了那些事情能。
一般而言,App的启动时间,是指涌入点击App开始,到用户看到第一个界面之间的时间。app 的启动包括三个阶段:
1 main()函数执行前
2 main()函数执行后
3 首屏渲染完成后
main() 函数执行前
在main函数执行前会做:
- 加载可执行的文件
- 加载动态链接哭,进行rebase 指针调整和符号bind
- Objc 运行时处理,包括Objc 相关类的注册、category注册、selector 唯一性检查等。
相应的,这个阶段对于启动优化来说,可以做的事情包括 - 减少动态库的加载。每个库本身有依赖关系,苹果建议使用更少的动态库,并且建议在使用动态库的数量较多时,尽量将多个动态库合并。数量上,苹果可以支持6个非系统动态库合成一个
- 减少加载启动后不会去使用的的类和方法
- +(load)方法里的内容可以放到首屏渲染后去完成,或是用+initalize()方法替换。因为一个load 方法会带来4毫秒的耗时。
- 控制c++ 全局变量的数量
mian()函数后
main()函数执行后的阶段,是指从main 函数执行开始,到appDelegate 的didFinishLaunchingWithOptions方法里首页离屏渲染的相关执行方法执行完成。
首页的业务代码都是在这个阶段,也就是首页离屏渲染前执行包括:
- 首页初始化需要配置文件的读写操作
- 首页列表大数据的读取
- 首页渲染的大量计算
很多时候,开发者会把各种初始化工作都放到这个阶段执行,导致渲染完成滞后。更加优化的开发方式,应该是从功能上梳理那些是首屏渲染必要的初始化,那些是app 启动必要的初始化功能,而那些是功能需要使用的时候才需要的。