# App startup 的抓取和展示说明 应用启动分析功能主要是提供应用启动分析模板帮助系统调优人员做应用启动慢场景问题分析,快速查找系统侧启动慢阶段和耗时长调用栈信息。 ### App startup 抓取参数的配置 ![GitHub Logo](../../figures/appstartup/appstartupconfig.jpg) 配置项说明: - App startup:配置项的总开关。 ### App startup 展示说明 将抓取的 App startup 文件导入到 smartperf 工具中,查看应用启动各阶段耗时的情况。 ### App startup 泳道图展示 App startup 的泳道图展示: ![GitHub Logo](../../figures/appstartup/appstartuprow.jpg) 应用启动包括六个阶段,分别是 Process Creating(应用进程创建阶段)、Application Launching(加载应用阶段)、UI Ability Launching(加载 UI Ability)、UI Ability OnForeground(应用进入前台)、First Frame - APP Phase(首帧渲染提交-应用)、First Frame - Render Phase(首帧渲染提交-Render Service)。每个阶段的 Slice 上都会显示出该阶段的时延。 ### App startup 泳道图点选功能 可以对启动各个阶段的 Slice 进行点选,点选后在最下方的弹出层中会展示点选数据的统计的 tab 页。 以 Process Creating 的 Slice 点选为例: ![GitHub Logo](../../figures/appstartup/appstartupslice.jpg) - StartTime(Relative): 应用启动开始时间(相对时间)。 - StartTime(Absolute): 应用启动开始时间(绝对时间)。 - EndTime(Relative):应用启动的结束时间(相对时间)。 - EndTime(Absolute):应用启动的结束时间(绝对时间)。 - Duration:应用启动的持续时间。 ### App startup 泳道图 Tab 页跳转功能 点击各阶段的起始或者结束时间后面的跳转图标,跳转至关联 Slice,并显示该 Slice 的详细信息。 以 Process Creating 的跳转为例: ![GitHub Logo](../../figures/appstartup/appstartupjump.jpg) 跳转说明: - StartTime(Relative)的跳转: 跳转到H:virtual int OHOS::AAFwk::AbilityManagerService::StartAbility关键字函数。 - EndTime(Relative)的跳转: 跳转到H:virtual void OHOS::AppExecFwk::AppMgrServiceInner::AttachApplication关键字函数,并且调用栈要带##应用名,如##com.ohos.smartperf。 ### App startup 泳道图的框选功能 应用启动阶段泳道图框选功能主要是框选启动分析泳道图之后,统计应用各个启动阶段的耗费时长信息。 ![GitHub Logo](../../figures/appstartup/appstartupdrag.jpg) - Process / Startup: 应用名称和启动阶段名称。 - Duration:应用各阶段启动时长。 - %:应用各阶段启动时长的占比。 ### So 初始化泳道图展示 So 初始化的泳道图展示: ![GitHub Logo](../../figures/appstartup/staticinitilizationrow.jpg) ### So 初始化泳道图的点选功能 点选 So 初始化的 Slice,展示该 so 初始化信息的 tab 页。 ![GitHub Logo](../../figures/appstartup/staticinitilizationslice.jpg) - Name:So的名称。 - StartTime(Relative):So初始化开始时间(相对时间)。 - StartTime(Absolute):So初始化开始时间(绝对时间)。 - Duration:So初始化耗时。 ### So 初始化泳道图 Tab 页跳转功能 点击 So 初始化开始时间后面的跳转图标,跳转至关联 Slice,并显示该 Slice 的详细信息。 ![GitHub Logo](../../figures/appstartup/staticinitilizationjump.jpg) 跳转说明: - StartTime(Relative)的跳转: 跳转到dlopen: system/lib64/extensionability/libinputmethod_extension_module.z.so。 ### So 初始化泳道图的框选功能 So 初始化泳道图框选功能主要是框选 So 初始化泳道图之后,统计各个进程下各个 So 的初始化耗费时长信息。 ![GitHub Logo](../../figures/appstartup/staticinitilizationdrag.jpg) - Process / Lib: 应用名称和So名称。 - Duration:So的耗费时长。