性能优化之使用Android profile跟踪耗时方法

AndroidStudio3.0之后增加了anroid profile,Profile分为三大块分析:CPU、内存和网络,本篇主要介绍内存分析。

这里我们主要通过Android profile 的CPU分析功能来定位耗时方法,以优化应用的流畅度。

这里我们直接通过操作实例来解决问题:

一.首先看这里需要解决的问题:

 app中点击如下按钮到见到页面会有明显的停顿时间:

针对这个问题我们通过profile来分析看下在哪里耗时了。

二.打开profile,点击下图红框按钮运行程序:

运行成功后如下图,提供了,CPU、MEMORY(内存)、NETWORK(网络)三方面的分析:

 

三.打开cpu分析

点击上图cpu那一行,进入cpu分析页面:

 

四.关键步骤来了,这时候我们需要分析我们需要优化的步骤有哪些方法耗时,这时候cpu分析页面右键鼠标,选择Record CPU trace:

 

然后回到app点击觉得耗时的按钮,等页面显示出来后,然后同上右键cpu分析页面,选择Stop recording:

 

这时候我们就记录下从点击按钮到出现页面这段时间方法的耗时情况了:

 

我们查看Call Chart情况如上图,Call Chart 标签提供函数跟踪的图形表示形式,其中,水平轴表示函数耗费的时间,垂直轴显示其被调用者。 橙色表示系统 API 的函数调用,绿色表示应用自有函数的调用,蓝色表示第三方 API(包括 Java 语言 API)的函数调用,所以这里我们主要看绿色的块的耗时情况。

五.从分析中我们找到了耗时方法:

找到方法后我们解决起来就容易了,我们看下代码,代码中doGetData调用了四个方法:

 

我们看到前两个方法都是获取本地缓存数据的方法:

 

两个方法都是在主线程执行的,所以增加了耗时,造成了页面显示卡顿,我们先把这两个缓存方法注释了看下:

 

可以看到时间明显降低了,这时候我们就可以根据这个优化这两个缓存方法。

 

 
————————————————
版权声明:本文为CSDN博主「lywyb112」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/liulanzaijia/article/details/87878479

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值