android 界面绘制完毕,几种获取android 界面性能数据的快捷方法

探测 界面绘制性能

获取界面的绘制性能有很多种方法,比如说 Systrace 但是这种方法 有一个不太好的地方就是使用起来较为复杂, 有没有一种 谷歌官方推荐 的方便一点的方法 ,其实是有的,只需要一个函数 就可以获得layout的时间 非常适合于 我们平时开发中 测试页面性能。

//调试界面性能时使用,可打印关键的layout耗时,使用完毕需删除

fun Activity.printPerformanceForLayout(tag: String = "performance") {

val handlerThread = HandlerThread("FrameMetrics")

handlerThread.start()

val handler = Handler(handlerThread.looper)

if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.N) {

window.addOnFrameMetricsAvailableListener({ _, frameMetrics, _ ->

val frameMetricsCopy = FrameMetrics(frameMetrics)

//返回的是纳秒

val layoutMeasureDurationNs = frameMetricsCopy.getMetric(FrameMetrics.LAYOUT_MEASURE_DURATION)

//多数情况下更习惯于ms

val layoutMeasureDurationMs = layoutMeasureDurationNs.toDouble() / 1000000.toDouble()

//如果有超过16ms的输出 那就要考虑你的界面是否需要进行优化了

Log.v("wuyue", "layoutMeasureDurationMs:" + layoutMeasureDurationMs)

}, handler)

}

}

复制代码

看下运行结果:

AAffA0nNPuCLAAAAAElFTkSuQmCC

可以根据log的结果 来 估算页面的渲染性能。类似于这种》=16ms 才layoutMeasure一次的,显然是界面有了卡顿

界面首次绘制完成时间

通常而言,我们有时候还希望获取到界面启动 到“界面绘制完成” 的时间 为什么要加引号? 因为 往往 ActivityTaskManager: Displayed 展示出来的结果 仅仅是

表示了从启动应用到系统认为其 “已启动” 所花费的时间,其中包括绘制第一帧 (所以是 “已显示” 的状态)

但大部分的情况是我们界面启动以后 还会做一些业务上的操作 比如去io获取一些重要的信息 然后刷新ui 怎么获取到 界面启动 到这个时间点的耗时?

大部分人都是在在onCreate里面 获取一个时间戳 然后在业务操作完成的时间点 再获取一个时间戳 然后算一下 差额,

其实现在就有更简便的写法

reportFullyDrawn

在你认为合适的地方 调用这个函数 然后观测如下日志:

AAffA0nNPuCLAAAAAElFTkSuQmCC

这是一种更为简便的观测方法

更快捷的获取activity的启动时间

有时候我们喜欢观察如下日志:

AAffA0nNPuCLAAAAAElFTkSuQmCC

来获取activity的启动时间

但其实有时候 这样也挺不方便的,尤其是需要频繁测试一个页面的启动性能

老是靠手点 很不方便,其实可以用 shell 命令来完成:

adb shell am start-activity -W -n 包名/activity名称

复制代码

AAffA0nNPuCLAAAAAElFTkSuQmCC

也可以对脚本的执行结果 进行grep 只抽取你关键的total time 进行展示

adb shell am start-activity -W -n 包名/activity名称 | grep "TotalTime" | cut -d ' ' -f 2

复制代码

adb shell am start-activity -S -W -R 100 -n 包名/activity名称

复制代码

获取应用冷启动 性能

有时候我们需要统计app的冷启动性能,单次结果往往不准确 还需要多次统计以后 做平均值

也可以用如下脚本来实现, 注意不是单引号 而是 `

for i in `seq 1 100`

do

adb shell am force-stop com.vivo.space

sleep 2

adb shell am start-activity -W -n 包名/activity名称 | grep "TotalTime" | cut -d ' ' -f 2

done

复制代码

效果如下:

AAffA0nNPuCLAAAAAElFTkSuQmCC

作者:vivo祁同伟

链接:https://juejin.cn/post/6953221575860568077

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/468072.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

联想rd650怎么装系统win7_Lenovo g50重装win7系统|U盘重装联想g50笔记本系统

Lenovo可以说是个家喻户晓的品牌很多小伙伴们也是使用联想的电脑,今天有小伙伴和小编提了一款Lenovo g50笔记本,小编了解到这款笔记本电脑的口碑和销量都很不错,其实这位小伙伴的问题呢是要如何重装win7系统,毕竟质量再好的电脑也…

书籍推荐

今天天气很好,风和日丽,艳阳高照,大家心情应该也很不错,毕竟,今天是周五,就像上学的时候一样,下午的铃声一响,每个同学都像脱缰的野马一样,周五,上班族的人们…

【转】JMeter学习(十三)分布式部署

Jmeter 是Java 应用,对于CPU和内存的消耗比较大,因此,当需要模拟数以千计的并发用户时,使用单台机器模拟所有的并发用户就有些力不从心,甚至会引起JAVA内存溢出错误。为了让jmeter工具提供更大的负载能力,j…

android mvp框架基类,Android MVP架构模式基类封装

前言MVP模式是Android官方推荐的架构模式,可使视图与数据层完全解耦。本文旨意封装在MVP模式中的基类如Activity,Fragment,Presenter类。以下内容建议在了解了mvp模式的读者阅读,如果还有对mvp架构模式有疑问的,请看我…

C语言,字符串指针做函数参数

看一下下面这段代码有什么问题?#include "stdio.h" //#include "stdbool.h" #include "string.h" #include "stdlib.h" #include "math.h"void getMemory(char *p) {/*char *p str*/p (char *)malloc(100);str…

java创建一个未知长度的数组_Java数组的创建操作

数组是一个固定长度的,包含了相同类型数据的 容器步骤1:声明数组步骤2:创建数组步骤3:访问数组步骤4:数组长度步骤5:练习-数组最小值步骤6:答案-数组最小值步骤 1 : 声明数组int[] a; 声明了一个数组变量。[]表示该变量是一个数组int 表示数组里的每一个元素都是一个…

Linux内核中的GPIO系统

一、前言作为一个工作多年的系统工程师,免不了做两件事情:培训新员工和给新员工分配任务。对于那些刚刚从学校出来的学生,一般在开始的时候总是分配一些非常简单的任务,例如GPIO driver、LED driver。往往CPU datasheet的关于GPIO…

初识函数集锦

python之路——初识函数 阅读目录 为什么要用函数  函数的定义与调用  函数的返回值  函数的参数  本章小结为什么要用函数 现在有一个需求,让你计算hello world的长度,你怎么计算? s1hello world length0 for i in s1:length1 print…

送你一个Git命令地图

上周,公众号举办了一个活动,抽取Git鼠标垫,现在已经结束了,大家不用再过去找,周末我收到了鼠标垫,然后看到有几个读者朋友圈也发了,我感觉也算是做了一个好事,拿到鼠标垫&#xff0c…

文件的权限与隐藏属性

一、文件的属性 1. 权限详解 r 表示读权限————————————读取文件内容 w 表示写权限————————————编辑、新增、修改内容(非删除) x 代表执行权限———————————读取文件内容 — 表示没有该权限——————————读取文件内容 2. 权限对目录的重…

利用insert、update和delete命令可以同时对多个表进行操作_学习笔记-操作系统(1)...

概念负责管理协调硬件、软件等计算机资源的工作为上层用户、应用程序提供简单易用的服务是一种系统软件功能和目标资源的管理者处理机管理:进程管理(进程控制、进程同步、进程通信、死锁处理、处理机调度)存储器管理:内存管理&…

uboot和Linux内核移植

这篇文章是一个读者昨晚发给我的,文章很长,里面的细节也比较多,但是微信公众号只能发 50000 字的文章,如果想阅读全文。请发送「 uboot和Linux内核移植 」到公众号后台获取下载链接。这篇文章是一个读者昨晚发给我的,文…

android界面元素识别,Android 10不能使用uiautomatorviewer定位元素的终极解决方法

Android app 元素定位除了使用Appium Inspector 外,还可以使用Android SDK 里tools中的uiautomatorviewer 工具。但今天打算使用 uiautomatorviewer 进行元素定位的时候,发现无法截图,并报如下错误:Unexpected error while obtain…

小程序背景图满屏_竞赛答题小程序

越来越多的企业部门团体举办知识竞赛答题活动,根据更加好玩的答题活动规则开发了本款知识竞赛答题小程序。本知识竞赛答题小程序采用云开发,无需搭建服务器,无需域名即可使用数据管理能力,更方便答题活动等场景,无需域…

STM32的map文件学习笔记

前言 前几个月针对公司自己的芯片写了个程序,这个程序有个硬性要求,就是能用的FLASH空间只有4KB,之前已经写得差不多了,最终占用空间3.6KB。这不,最近又得加需求,还剩一点点FLASH空间可以使用,这…

html网易云音乐图片轮播效果,Vue之网易云音乐PC版轮播图的实现

Github - program-learning-lists最近在刷网易云音乐歌单时发现首页的轮播图很有意思,正好自己想尝试做一个PC版的网易云音乐,于是就是使用Vue去做这个demo,废话少说,我要出招了,接招吧页面的DOM结构:style"slide…

深入理解mybatis原理, Mybatis初始化SqlSessionFactory机制详解(转)

文章转自http://blog.csdn.net/l454822901/article/details/51829785 对于任何框架而言,在使用前都要进行一系列的初始化,MyBatis也不例外。本章将通过以下几点详细介绍MyBatis的初始化过程。 1.MyBatis的初始化做了什么 2. MyBatis基于XML配置文件创建C…

我有个队友,叫悟空

昨晚,是我们篮球队年终聚会,好像也是第一次组织篮球队的聚会,之前就只知道在场上打球,场下就没有过这样的吃饭聚会。年终的时候,聚会特别多,该交流感情的交流感情,该年会抽奖的就年会抽奖&#…

C#基于LibUsbDotNet实现USB通信(一)

网上C#USB通信的资料比较少, 基本上都是基于LibUsbDotNet 和 CyUsb, 关于打印机设备的还有一个OPOS。 本篇文章基于LibUsbDotNet。 1. 下载并安装 LibUsbDotNet 安装文件。 2. 运行Filter Wizard, Install a device filter。 安装需要通信的usb设备。 3. 建一个简单…

一个大神的Android成长之路

这篇文章是我的一个朋友写的,总结了这些年的技术成长之路,我觉得对于很多技术人都有借鉴的作用,技术是相通的,不要整天想一口气吃成一个胖子,不积跬步无以至千里,既然选择了技术这条路,就不畏艰…