应用启动耗时统计
在对应用主页进行配置后,rabbit
可以统计出如下图所示的冷启动耗时:
页面渲染与网络请求耗时统计
与网络请求耗时结合后,rabbit
可以统计出一个页面的完全渲染耗时。这里的完全渲染耗时是指:从页面create到页面拿到请求结果并刷新页面所用的时间。核心思想参考自:Android自动化页面测速在美团的实践,最终统计的页面耗时如下图所示:
慢函数检测
基于编译时代码插桩, rabbit可以准确的统计每一个函数的耗时,并筛选出慢函数。
慢函数定义为: 在主线程消耗时间超过一定阈值的函数(rabbit也支持配置检测其他线程的慢函数)。
rabbit
支持分包检测慢函数:
支持查看每一个包下的慢函数列表以及每一个慢函数的堆栈:
代码扫描
通过提供给rabbit
一份代码扫描列表,rabbit可以在编译时扫描出这些代码调用的位置。默认会扫描一些阻塞代码, 比如下面这种:
SharePreferences$Editor.commit()
最终扫描结果会展示如下:
点击右上角导出按钮可以把扫描结果以json
的形式导出到SD卡中。
网络日志监控
rabbit可以记录网络请求日志并方便的查看返回的json
数据:
卡顿日志监控
rabbit通过Choreographer
来检测主线程的运行情况,并异步采集主线程堆栈来还原卡顿现场。
对于下面代码:
Thread.sleep(2000)
rabbit会获得如下的卡顿采集结果:
FPS分析
rabbit会在主线程looper运行时计算主线程FPS并实时的显示出来:
rabbit支持分页面分析FPS:
内存分析
功能类似于FPS分析
,rabbit支持实时显示内存使用情况并分页面分析内存占用情况:
分页面内存统计:
异常捕获
通过设置Thread.setDefaultUncaughtExceptionHandler
,rabbit可以捕获java层异常并展示出来:
内存泄漏捕获
rabbit集成了leakcanary 2.0
。
apk包分析
rabbit提供了一个可执行的jar包, 它可以准确的分析出apk中的大图、重复文件、apk包大小与内容组成。核心思路参考自Matrix APK包分析。
运行方式为:
java -jar apk-analyzer.jar apk-analyzer-config.json
apk-analyzer-config.json
用来配置待分析的apk路径以及mapping文件位置等信息:
{
“apkPath”:“xxxx/app-Release.apk”,
“methodGroup”:[{
“name”:“xxx”,
“package”:“com.xxx.xx”
}],
“classMappingFilePath”:“xxx/xxx.txt”,
“maxImageSizeKB”:30
}
最终分析结果会输出到一个json文件中:
apk-analyzer-result.json
{
“AppInfo”: {
“versionCode”: “1004000”,
“versionName”: “1.4.0”,
“appSize”: “21.51 MB”
},
“BigImageRes”: [
{
“name”: “assets/flutter_assets/images/icons/xxLogo.png”,
“size”: “76.73 KB”
}
…
…
],
“ApkCompose”: [
{
“type”: “so”,
“totalSizeStr”: “8.05 MB”
},
{
“type”: “dex”,
“totalSizeStr”: “6.54 MB”
}
…
…
],
“DuplicatedFile”: [
{
“files”: [
“res/drawable-xxhdpi-v4/bg_home_water_ripple.webp”,
“res/drawable-xxhdpi-v4/bg_keyboard_shadow_line.webp”
],
“fileSize”: “”,
“md5Value”: “d41d8cd98f00b204e9800998ecf8427e”
}
…
],
“MethodCount”: {
“total-count”: 127732,
“com.xxx.xx”: 14800,
“other-pkg”: 112932
}
}
上报APK分析结果
需要在apk-analyzer-config.json
中配置上报路径:
{
“apkPath”:“xxxx/app-Release.apk”,
…
“uploadPath”:“xxxxxx/upload”
}
上报的数据格式与rabbit的基本上报数据格式保证一致:
数据上报
rabbit目前支持上报大部分检测数据。通过一些简单的配置就可以把检测数据上报到后台。rabbit数据上报的基本格式如下:
{
“device_info_str”: “{…}”,
“info_str”: “{…}”,
“time”: 1577775888933,
“type”: “fps_info”,
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
尾声
如果你想成为一个优秀的 Android 开发人员,请集中精力,对基础和重要的事情做深度研究。
对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。
这里,笔者分享一份从架构哲学的层面来剖析的视频及资料分享给大家梳理了多年的架构经验,筹备近6个月最新录制的,相信这份视频能给你带来不一样的启发、收获。
PS:之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)
架构篇
《Jetpack全家桶打造全新Google标准架构模式》
(含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)
[外链图片转存中…(img-lzOiplzR-1712001551113)]
架构篇
《Jetpack全家桶打造全新Google标准架构模式》
[外链图片转存中…(img-Dx1VHuxi-1712001551113)]文章来源:https://www.toymoban.com/news/detail-850280.html
本文已被CODING开源项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》收录文章来源地址https://www.toymoban.com/news/detail-850280.html
到了这里,关于开源 _ 新一代Android 性能监控框架Rabbit的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!