安卓性能监控(APM)之启动时间监控
发布日期:2021-06-29 18:29:32
浏览次数:2
分类:技术文章
本文共 986 字,大约阅读时间需要 3 分钟。
App启动流程图
App启动流程说明
- 点击桌面App图标,Launcher进程采用Binder IPC向system_server进程发起startActivity请求;
- system_server进程接收到请求后,向zygote进程发送创建进程请求;
- Zygote进程fork出新的子进程,即App进程;
- App进程,通过Binder IPC向sytem_server进程发起attachApplication请求;
- system_server进程在收到请求后,进行一系列准备工作后,再通过binder IPC向App进程发送scheduleLaunchActivity请求;
- App进程的binder线程(ApplicationThread)在收到请求后,通过handler向主线程发送LAUNCH_ACTIVITY消息;
- 主线程在收到Message后,通过发射机制创建目标Activity,并回调Activity.onCreate()等方法。
- 至此,App进入Activity生命周期,执行完onCreate/onStart/onResume方法,UI渲染结束后便可以看到App的主界面。
监控App启动时间方案
- 完整监控 要完整的监控App启动时间,需要从用户点击桌面应用图标开始,但是因为那时我们的应用还没有启动,无法在代码里完成监控.
- 应用内监控
- 方案描述 监控从Application初始化开始到首页的activity完成展示为止. PS:当activity调用onWindowFocusChanged时,UI就完全展示了.
- 冷启动和热启动 冷启动是App没有被启动过,进程不在内存中,点击桌面图标到看到首页. 热启动是App曾经启动过,进程还在内存中,点击桌面图标到看到首页. 冷启动时间: 从Application到首页Activity的onWindowFocusChanged. 热启动时间:从第一个Activity的onCreate到首页Activity的onWindowFocusChanged.
- 时间计算陷阱 虽然上图的时间计算看似非常简单,但是实际还有陷阱. 因为启动应用到首页的过程中还可能出现欢迎界面,请求权限界面,登陆界面等等.这些场景出现时,统计时间应该作废,不算做正常的启动时间.
源代码
参考资料
关注头条号,第一时间获取最新文章:
转载地址:https://cxyxy.blog.csdn.net/article/details/106419760 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
做的很好,不错不错
[***.243.131.199]2024年04月09日 09时28分25秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
堆优化的Dijkstra算法(邻接表+优先队列+pair)
2019-04-30
Dijkstra算法-->改编自《啊哈!算法》
2019-04-30
高精度加法(C++实现)
2019-04-30
高精度减法(C++实现)
2019-04-30
高精度乘法(C++实现)
2019-04-30
高精度乘低精度(利用C++ STL vector实现)
2019-04-30
Floyd算法-->整理自《啊哈!算法》
2019-04-30
多重背包问题(二进制优化)
2019-04-30
字符串模式匹配 <-- BF算法
2019-04-30
字符串模式匹配 <-- KMP算法
2019-04-30
KMP算法中计算next数组的代码
2019-04-30
洛谷 P1226 快速幂
2019-04-30
01背包问题(一维数组优化)
2019-04-30
集合类LinkedList创立的元素tempList之遍历及删除
2019-04-30
BigDecimal
2019-04-30
自定义打印输出数组
2019-04-30
通过键盘输入内容到文件中
2019-04-30
第一章 计算机网络概论
2019-04-30
天赋和努力
2019-04-30
Nginx服务问题总结
2019-04-30