这次我们依旧来谈谈有关性能优化的话题,这次我们会用到Google给我们提供的分析工具——Systrace。如果你还不了解这个工具,最好先了解一下。Google 官方文档:
https://developer.android.com/studio/command-line/systrace
我们还会用到一个Demo,用来对比卡顿和不卡顿的状况。

问题重现

Demo运行起来会是这样的:
流畅运行

模拟卡顿

这里解释一下,GIF动画表现得不是很完善,流畅运行的效果其实是每秒60帧,实际运行效果非常顺畅。模拟卡顿的效果在每秒60帧的基础上加了随机时长的线程sleep时间。具体实验代码片如下所示:

流畅运行的代码片

     threadRun = true;pbCurrent = 0;demoPb.setProgress(pbCurrent);new Thread(new Runnable() {@Overridepublic void run() {while (threadRun) {try {Thread.sleep(1000 / 60);} catch (InterruptedException e) {e.printStackTrace();}if (pbCurrent > PB_MAX) {pbCurrent = 0;} else {pbCurrent++;}Message msg = new Message();msg.what = UPDATE_HANDLER_KEY;mUiHandler.sendMessage(msg);}}}).start();

模拟卡顿的代码片

     thread2Run = true;pbCurrent = 0;demoPb.setProgress(pbCurrent);new Thread(new Runnable() {@Overridepublic void run() {while (thread2Run) {try {Thread.sleep(1000 / 60);Thread.sleep(new Random().nextInt(200));} catch (InterruptedException e) {e.printStackTrace();}if (pbCurrent > PB_MAX) {pbCurrent = 0;} else {pbCurrent++;}Message msg = new Message();msg.what = UPDATE_HANDLER_KEY;mUiHandler.sendMessage(msg);}}}).start();

更新UI部分代码片

     @Overridepublic void handleMessage(Message msg) {super.handleMessage(msg);switch (msg.what) {case UPDATE_HANDLER_KEY:demoPb.setProgress(pbCurrent);break;}}

两个按钮分别对应上述两个线程的使能,另外请注意:我们只是模拟卡顿,并非真的发生了卡顿。因此,在Systrace的图表中,没有出现红色或橙色的告警。
分别对上述两种情况取Systrace图表,得到如下结果:

流畅运行的图表

模拟卡顿运行的图表

通过对比,我们可以看到上面二者之间的差别。流畅运行的图表中,每一帧的绘制很均匀。差不多16.6ms一帧,也就是1000毫秒除以60帧,得到的16.6ms一帧。而模拟卡顿的图表中,每一帧的绘制则不均匀,有的长达将近200ms。但由于是我们自身模拟的结果,并非实际卡顿,所以图表中均为绿色的显示。下面我们来看一个真实的案例:

真实案例

上图中,一帧本来应该是16ms完成的,然而却花费了近60ms,用1000ms/60ms,我们得到近似16帧。而16帧的帧率已经是肉眼可见的卡顿了。

揪出凶手

我们聚焦到上面真实的案例,放大看发生卡顿的位置:

我们发现,Record View 的draw()方法花费了一些时间。

此外,还有一堆琐碎的小片段,我们进一步放大观察,会发现:

这里居然还加载了一堆贴图。
至此,我们就抓到了导致掉帧的“元凶”,下一步就是结合源代码进行优化了。

一些疑问和技巧

为什么16ms一帧?
16ms是1000ms/60帧得到的结果,60帧对于人眼而言已经是很流畅的体验了。而最低的限度是33ms一帧,也就是1000ms/30帧得到的结果。如果时间再长一点的话,就有可能发生人眼可见的卡顿了。
延伸一点,也就是说,如果严格要求60帧,但是中间掉了1帧,就相当于33ms画一帧,此时,虽然掉帧,但是人眼还是可接受的。

如何快速定位卡顿位置
首先是确保发生了卡顿。一般而言,没有发生卡顿的图表,网页的图表会是绿色的,发生卡顿的则是红色的。

然后我们使用键盘+鼠标的组合来找位置,键盘的快捷键对应W、S、A、D。AD相当于拖拽时间滑块,WS相当于缩放。
最后我们用鼠标来选取相应的时间范围即可。

今天的分享到此,希望对你有帮助。

抓出卡顿元凶,从分析掉帧开始相关推荐

  1. 开黑不卡顿,运行不掉帧,高通骁龙 835 助力 NEST 2017 王者荣耀组决赛

    在 Android 阵营中,高通骁龙 835 已经成为高端旗舰智能手机产品的标配:而高通在推广自家产品的认知度方面也是不遗余力. 9 月 17 日,由"高通骁龙"提供赞助并冠名的 ...

  2. 关于最新Solidworks2018大型装配设计、仿真渲染并行计算卡顿慢的分析与解决方案

                  关于最新Solidworks2018大型装配设计.仿真渲染并行计算卡顿慢的分析与解决方案 (一)三维设计与仿真并行计算的卡顿慢问题分析 Solidworks是CAD专业领域 ...

  3. 风暴英雄出现服务器未响应,《风暴英雄》游戏卡顿的原因分析及解决办法

    <风暴英雄>游戏卡顿的原因分析及解决办法 2014-11-02 15:14:47来源:游戏下载编辑:阿狸桃子评论(0) <风暴英雄>内测一周以来,有不少玩家反映玩起来比较卡.那 ...

  4. 2018最新4k超高清视频编辑,解码,编码,数据压缩,特效合成,调色,影视后期,卡顿慢问题分析

       2018最新4k超高清视频编辑,解码,编码,数据压缩,特效合成,调色,视频渲染输出,影视后期,卡顿慢问题分析 4K视频时代到来,影视后期制作的各个环节(如视频剪辑.特效合成.视频调色.视频输出等 ...

  5. 性能优化系列(一)找出卡顿的元凶 —— 渲染性能优化

    文章首发「Android波斯湾」公众号,更新地址:https://github.com/jeanboydev/Android-ReadTheFuckingSourceCode 一个 Android 应 ...

  6. 视频融合云平台视频播放卡顿的原因分析及解决办法

    SkeyeVSS视频融合云平台可在复杂的网络环境中,将分散的各类视频资源进行统一汇聚.整合.集中管理,平台支持多类型设备.多协议方式接入,包括主流标准协议国标GB/T28181.RTMP.RTSP/O ...

  7. 饥荒服务器怎么显示帧数,进化游戏卡顿优化方法 附最高帧数120帧设置方法

    作为一款次时代游戏,进化卡顿问题是可以想象的,特别是如果你选择操作怪物的话,有时候进食或者走路都会出现莫名其妙的卡顿,下面小编就给大家各位A卡和N卡玩家提供一个优化卡顿问题的方法,希望能够缓解大家的卡 ...

  8. js 渲染十万条数据卡顿优化方法。请求帧渲染

    函数: 1.window.requestAnimationFrame(callback) callback:下一次重绘之前更新动画帧所调用的函数(即上面所说的回调函数). 作用:告诉浏览器--你希望执 ...

  9. nvme固态硬盘开机慢_安装固态硬盘后,开机却慢如蜗牛,找到卡顿元凶,让电脑运行如飞...

    现在的电子产品更新速度越来越快,尤其是手机和电脑,每一年都会有新的产品出现.尤其是电脑,随着现在的软件越来越大,一些老旧电脑的配置已经无法胜任了,现在电脑上安装固态硬盘已经成为了主流,正是因为固态硬盘 ...

最新文章

  1. 【Matlab】求解积分方程的数值解
  2. 痞子衡嵌入式:开启NXP-MCUBootUtility工具的BEE加密功能 - image_enc
  3. JS Math.round()方法原理
  4. Java毕设动物管理系统_java毕业设计_springboot框架的现代化动物园管理系统EB
  5. Linux常用命令(二)——超详版
  6. CentOS 快速安装ftp
  7. php10充电宝拆解,【变废为宝拆解】拆解一个正品的小米移动电源10400mAh版
  8. python领域驱动_DDD领域驱动设计学习初探
  9. 《老路用得上的商学课》56-60学习笔记
  10. 医学超声成像—合成孔径法(Synthetic Aperture Methods)[3]
  11. Python安全工具编写-pcap流量包重放
  12. yolov5 训练结果解析
  13. 解决word中插入visio对象的图片大小修改问题
  14. 【AUDIO音频兴趣拓展】如何测试喇叭端功率?音频功放输出端测试到波形为方波
  15. 北京科技大学871计算机真题,(NEW)北京科技大学871计算机综合一(含计算机组成原理、数据结构)历年考研真题汇编(350页)-原创力文档...
  16. 假作真时真亦假,无为有处有还无
  17. 无线产品认证logo
  18. 计算机一级MS Office知识点归纳整理
  19. ul中的li横排问题
  20. Linux实战后50讲 幕布笔记

热门文章

  1. 3大全球性趋势宣告品牌长期主义时代已来,年轻一代消费者更追求感性价值 | 美通社头条...
  2. 针对家庭用户的6个物联网提示
  3. 9月19号-9月21号丰宁坝上草原行 - 营销系统 - 京东内部论坛 - Powered by Discuz!
  4. 已知男程序员穿格子衫,那么女程序员会穿格子裙吗?
  5. 获取计算机本机信息命令大全(WMIC指令、硬盘、网卡等)
  6. Docker 之 基础篇(安装、卸载、阿里云镜像加速、常用命令、发布、应用安装)
  7. Web安全测试---跨站请求伪造CSRF
  8. 揭秘:刘备追得最辛苦的人不是诸葛亮
  9. python实现矢量积、叉积、外积、张量积
  10. 年内再开通三条地铁线,深圳地铁将超500公里