从点击图标启动程序到didFinishLaunchingWithOptions首页viewDidLoad加载完成,是一次完整的启动过程。
从后台从新进入前台
按照main调用之前和之后可以分为两个个阶段:
- T1:pre-main阶段,即main()函数之前,即操作系统加载App可执行文件到内存,然后执行一系列的加载&链接等工作,最后执行至App的main()函数;
- T2:main()函数之后,即从main()开始,到appDelegate的didFinishLaunchingWithOptions方法执行完毕前这段时间,主要是构建第一个界面,并完成渲染。
分析两个阶段都做了什么操作才能有针对的优化
苹果提供了内建的测量方法,在 Xcode 中 Edit scheme -> Run -> Auguments 将环境变量 DYLD_PRINT_STATISTICS
设为 1。
也可以用instrument
的Time profile
另一种方法:
配置Build Options—>Debug Information Format的debug模式下选择DRAF with dSYM File
Edit Scheme—>profile—>Build Configuration选择debug
comman