本文章转载于搜狗测试
问题背景:PP 在测试机运行一段时间后出现手机发烫、卡顿、高 CPU 占有率的现象。如何去检查当前性能变化的原因是什么,可以使用android系统分析工具-traceview
traceView是Android 平台配备一个很好的性能分析的工具。它可以通过图形化的方式让我们了解我们要跟踪的程序的性能。TraceView是 Android 平台特有的数据采集和分析工具,它主要用于分析 Android 中应用程序的 hotspot。TraceView 本身只是一个数据分析工具,而数据的采集则需要使用 AndroidSDK中的 Debug 类或者利用 DDMS 工具。
一般有两种方式:
A、调用Debug类
在开始调试的地方,如Activity的OnCreate函数,添加
Debug.startMethodTracing("tracefilename");
在结束调试的地方,如Activity的OnCreate函数,添加;
Debug.stopMethodTracing();
之后运行你的app一段时间并退出会在sd卡根目录生成tracefilename.trace这个log文件,记录这段时间内的运行信息。将日志文件pull到PC端,cmd到android sdktools文件夹内(或绑定sdk tools目录到系统path内),运行traceviewtracefilename.trace即可打开TraceView分析界面
B、调用DMMS
DDMS中TraceView使用示意图如下,调试人员可以通过选择Devices中的应用后点击
按钮Start Method Profiling(开启方法分析)和点击Stop MethodProfiling(停止方法分析)
开启方法分析后对应用的目标页面进行测试操作,测试完毕后停止方法分析,界面会跳转到DDMS 的 trace 分析界面,如下图所示:
TraceView界面比较复杂,其UI划分为上下两个面板,即Timeline Panel(时间线面板)和Profile Panel(分析面板)。上图中的上半部分为Timeline Panel(时间线面板),Timeline Panel又可细分为左右两个Pane:
•左边Pane显示的是测试数据中所采集的线程信息。由图可知,本次测试数据采集了main线程,传感器线程和其它系统辅助线程的信息。
•右边Pane所示为时间线,时间线上是每个线程测试时间段内所涉及的函数调用信息。这些信息包括函数名、函数执行时间等。由图可知,Thread-1412线程对应行的的内容非常丰富,而其他线程在这段时间内干得工作则要少得多。
•另外,开发者可以在时间线Pane中移动时间线纵轴。纵轴上边将显示当前时间点中某线程正在执行的函数信息。
上图中的下半部分为Profile Panel(分析面板),Profile Panel是TraceView的核心界面,其内涵非常丰富。它主要展示了某个线程(先在Timeline Panel中选择线程)中各个函数调用的情况,包括CPU使用时间、调用次数等信息。而这些信息正是查找hotspot的关键依据。所以,对开发者而言,一定要了解Profile Panel中各列的含义。下表列出了Profile Panel中比较重要的列名及其描述。