traceview检测UI卡顿

20 篇文章 0 订阅
18 篇文章 0 订阅

1,  traceview  检测UI卡顿   ( Systrace 查找问题,traceview,systrace)  通过Android studio自带的traceview查看(Android profiler)

2,  ANR 定位

生成 trace 文件

使用代码
使用 Android Studio
使用 DDMS

1,1.使用代码生成 trace 文件
  Debug.startMethodTracing("shixintrace");    //开始 trace,保存文件到 "/sdcard/ocr_trance.trace"
    // ...
    Debug.stopMethodTracing();    //结束

代码很简单,当你调用开始代码的时候,系统会生产 trace 文件,并且产生追踪数据,当你调用结束代码时,会将追踪数据写入到 trace 文件中。

下一步使用 adb 命令将 trace 文件导出到电脑:

adb pull /sdcard/ocr_trance.trace /tmp


/sdcard/Android/data/com.okay.t_ocr/files/ocr_trance.trace   

trace.text文件  /data/anr/
2.androidStudio 

如上图所示,CPU Profiler的视图包括以下内容:
①App timeline:显示CPU在执行过程中的时间轴。
②线程 timeline:显示线程列表以及每个线程在某个时间段占用的CPU的资源情况。
③CPU timeline:列出CPU在App运行过程中CPU使用情况。
④Method Trace:在指定线程中,执行的方法栈,横行表示执行的时间轴,纵向表示方法执行的调用轴。


使用步骤
打开CPU Profiler界面
点击下方的红色圆点,开始记录(Record)堆栈(此时按钮变灰色),记录一段时间段后,再点击下停止记录(此时按钮变红色)
在②区域选择你用分析的线程
在③区域中选择要分析的CPU片段(只能有记录的CPU片段)
查看④区域,就会有一系列的执行方法队列显示出来,通过横向查看可以看出某个方法的执行时间(横向时间越长,执行的时间越长),通过纵向表示方法的调用关系。



Wall Clock Time: 计算整个CPU时间,一个方法从开始到return,都会计算在内。
Thread Time: 从整个CPU时间,减掉可能由JRE中断线程的时间。

OK这里就选择Wall Clock Time。


首先,最显眼的东西就是这个黄色的长条条了,每个长方形都是一个方法,长度代表这个方法执行的时间(就是上面咱们选择的Wall Clock Time啦)。Inclusive Time是指copyOf以及它的子方法调用的时间,占整个线程执行时间的占比。Exclusive Time与Inclusive Time相对,它不统计子方法执行的时间。

 
invocation Count 调用次数
inclusive Time :  执行时间(包括调用的方法执行时间)包含时间(inclusive time)花在执行函数的时间,包括函数调用,点击,则升降序排列耗时占比
Exclusive Time :  展示所有的方法耗时占比,不包括调用方法,单独这个方法执行的时间, 点击 则升降序排列耗时占比
 

参考文献:https://www.jianshu.com/p/7e9ca2c73c97

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值