IT技术之家

首页 > iOS

iOS

【移动应用开发篇】iOS APP启动过程_iosapp启动流程_商业资讯汇

发布时间:2023-11-28 21:07:17 iOS 33次 标签:大数据
iOS APP启动时长是衡量应用品质的重要指标,也是用户体验的重要因素,更是许多开发者努力优化的点。许多用户吐槽“APP为什么一直进不去啊?”等等问题,那么iOS系统是如何启动APP的呢?本文就一起了解一下吧!一、APP启动过程及优化进入主题:当我们点击icon到第一个页面展示完成,发生了什么样的过程?这个过程就是APP启动过程,也就是冷启动!APP启动总时间 = mian()之前 + main() 之后;1:main()函数之前程序要想运行,必须要有对应的运行环境,那么这个过程就是搭建...

iOS APP启动时长是衡量应用品质的重要指标,也是用户体验的重要因素,更是许多开发者努力优化的点。许多用户吐槽“APP为什么一直进不去啊?”等等问题,那么iOS系统是如何启动APP的呢?本文就一起了解一下吧!

一、APP启动过程及优化

进入主题:当我们点击icon到第一个页面展示完成,发生了什么样的过程?这个过程就是APP启动过程,也就是冷启动!

APP启动总时间 = mian()之前 + main() 之后;

1:main()函数之前

程序要想运行,必须要有对应的运行环境,那么这个过程就是搭建程序运行的环境。

App开始启动后,系统的dynomic loader首先加载可执行文件(.o文件),然后 dyld从可执行文件的依赖开始, 递归加载所有的依赖动态库(Dylib)。

dyld:dynomic loader动态链接器,作用是加载一个进程所需要的可执行文件,dyld是开源的

第一步:加载动态库

动态库包含:用到的所有系统 framework,以及一些libxxx的库,比如runtime的运行库:libobjc,运行GCD的库:libdispatch()。

加载动态库其实就是加载动态库的mach-o文件,主要加载过程如下:

找到动态库的mach-o文件

打开并验证文件

在系统注册文件

调用对应的各种启动函数

由于该过程也是需要时间处理的,因此可以如下优化:

1.不用或者少用非系统库

2.合并非系统库

3.使用静态库,只用到库的单一功能可以写成代码放入程序

总之:dyld 将 image(镜像:各种Mach-O文件) 加载到内存后,dyld 会通知Runtime进行下一步的处理

第二步:Runtime阶段

Runtime收到dyld的通知,就开始工作调用_init_objc()函数。开始解析内存中的images(镜像)

注册Objc类 (class registration),初始化类,元类对象

把category中的方法插入主类方法列表 (category registration)

调用Objc的+load()函数

C++的初始化方法

非基本类型的C++静态全局变量的创建(通常是类或结构体)

可执行文件和动态库中所有的符号(Class,Protocol,Selector,IMP,…)就会加载到内存中。

runtime处理完成后,runtime 的那些方法(动态添加 Class、swizzle 才能生效)。

由此可以做如下优化:

Objc类数量和 selector数量越少越好,删除无用(没用到)的类和方法

减少C++虚函数数量

使用swift stuct:减少符号的数量

通过对Mach-O文件的了解,可以知道__TEXT:__objc_methname:中包含了代码中的所有方法,而__DATA__objc_selrefs中则包含了所有被使用的方法的引用,通过取两个集合的差集就可以得到所有未被使用的代码

总结一下:对于main()调用之前我们可以如下优化:

1.少用framework,是否可以合并非系统库,因为动态链接比较耗时

2.check framework应当设为optional和required,如果该framework在当前App支持的所有iOS系统版本都存在,那么就设为required,否则就设为optional,因为optional会有些额外的检查

3.NSObject类数量和 selector数量越少越好,删除无用(没用到)的类和方法

4.+load()方法尽量延后调用,或者放在initialize()方法中执行

5.尽量不要用C++虚函数(虚函数指针与虚函数表。其中创建虚函数表有开销)

虚函数:通过基类指针只能访问派生类的成员变量,但是不能访问派生类的成员函数。虚函数virtual 可以访问。但是virtual需要用到虚函数指针与虚函数表,而创建虚函数表有开销。

2:main()之后

main()之后 主要工作就是初始化必要的服务,显示首页内容等。主要优化

Application:didFinishLaunchingWithOptions: 方法

- (BOOL)Application:(UIApplication *)Application didFinishLaunchingWithOptions:(NSDictionary *)launchOption {

//code ...

}

此时优化的方向主要是业务逻辑的优化

1.一些与UI展示无关的业务做延迟加载,比如各种认证,检测,注册等;

2.NSUserDefaults,FMDB等数据是否可以延后或者分开读取。

以上就是APP启动的流程及优化方法,在APP启动的过程中可能会出现耗时长等问题。我们可以借助友盟+u-apm的启动分析功能来捕捉错误根源,减少问题时间。

友盟+u-apm

在启动过程中发生的性能问题,我们可以通过借助启动分析工具——友盟+U-APM来监测。

启动场景是用户使用App的第一道关卡,启动慢、启动闪退都会直接从源头阻断客户使用,甚至会造成启动不成功新客户卸载的情况。很多技术团队都会以启动耗时作为重点性能监控指标。U-APM中启动分析包含启动趋势、慢启动分析和启动崩溃分析三大功能模块,帮助您把控应用的启动性能状态,从源头减少客户流失。