一、背景
随着业务代码的快速迭代,项目越来越大,启动时间越来越慢,用户体验不好,就可能卸载APP,失去流量。所以冷启动时间不容忽视,如果大于700ms,就要考虑冷启动优化了。
二、定义
一般把冷启动分为pre-main 和main两个阶段,但是也有分为三个阶段的,第三阶段是didFinishLaunchingWithOptions 到首页渲染完,我个人也是倾向于三个阶段。
阶段一:pre-main
- 装载APP的可执行文件
- 递归加载所有依赖的动态库
- 调用map_images进行可执行文件内容的解析和处理
- 在load_images中调用call_load_methods,调用所有的Class和Category的 + load方法
- 进行各种objc结构初始化(注册Objec类、初始化类对象等等)
- 调用C++ 静态初始化器和 _attribute_((constructor))修饰函数
阶段二:main
- main()
- UIApplicationMain()
- AppDelegate的application: didFinishLaunchingWithOptions:方法
阶段三:首页渲染
- 相关业务组件初始化
- 基础信息数据同步,首页数据请求
- 广告,弹层,一些第三方业务,等
- …
三、常用的检测工具
- Xcode:(Edit scheme -> Run -> Arguments DYLD_PRINT_STATISTICS设置为1,如果需要更详细的信息,那就将DYLD_PRINT_STATISTICS_DETAILS设置为1)
total time: 4.3 seconds (100.0%)
total images loaded: 529 (496 from dyld shared cache)
total segments mapped: 122, into 52321 pages
total images loading time: 1.9 seconds (46.2