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 : 展示所有的方法耗时占比,不包括调用方法,单独这个方法执行的时间, 点击 则升降序排列耗时占比
traceview检测UI卡顿
最新推荐文章于 2023-08-23 14:25:56 发布