iOS启动优化 —— 理论
1. app启动
启动的过程一般是指从用户点击app图标开始到AppDelegate 的didFinishLaunching方法执行完成为止,其中,启动也分为冷启动和热启动:
- 冷启动:第一次打开app或app被杀死后重新打开叫冷启动(走didFinishLaunchWithOptions方法)
- 热启动:app在后台且存活的状态下,再次打开app叫热启动(不走didFinishLaunchWithOptions方法)
启动优化通常指的是冷启动优化,冷启动一般分为两个部分,
- main函数之前 :一般叫做pre-main阶段,指的是唤起 App 到 main() 函数执行之前的过程。
- main函数之后:从main函数 到Appdelegate 的didFinishLaunching方法执行完成为止。
我们可以在 Xcode 中配置环境变量 DYLD_PRINT_STATISTICS来查看pre-main阶段的耗时(Edit Scheme -> Run -> Arguments ->Environment Variables点击+添加环境变量 DYLD_PRINT_STATISTICS),配置之后运行。这里可以看到pre-main阶段一共用了171.53ms
- dylib loading time(动态库耗时):主要是加载动态库。动态库载入耗时是难以避免的,因为只要有动态库,就会去载入,并且如果动态库有依赖关系的话,就会消耗时间去查找读取。苹果的系统库则有点不一样,因为它已经载入到内存了,已经在共享缓存空间,并且已经做了非常高速的优化,但是我们自定义的动态库则没有优化。所以苹果给我们一个建议就是动态库的个数不要大于6个。如果大于6个,那么尽可能的去进行动态库的合并。
- rebase/binding time:偏移修正/符号绑定耗时
- rebase(偏移修正):任何一个app生成的二进制文件,在二进制文件内部所有的方法、函数调用,都有一个地址,这个地址是在当前二进制文件中的偏移地址。每次启动的时候,系统都会随机