Traceview是一个图形查看执行日志,您创建使用Debug类日志跟踪信息在你的代码。Traceview可以帮助您调试您的应用程序和配置它的性能。
1.在开始使用TraceView你要注意:
你的设备和模拟器必须设置SD card和你的程序拥有对SDcard具有读写操作的权限(
<uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE" />)
2.在你的程序中使用TraceView
// 开始跟踪然后自动保存到"/sdcard/test.trace"
Debug.startMethodTracing("test");
// ...
// 停止跟踪
Debug.stopMethodTracing();
使用traceView就只需要这两个方法了…
举个例子我们可以在:
//onCreate方法中调用
onCreate(){
Debug.startMethodTracing("test");
}
//.............
// onDestroy方法中结束
onDestroy{
Debug.stopMethodTracing();
}
当然,你Debug的位置你可以随便设置,只要符合要求就行
3 导出trace文件,查看记录结果
使用 traceview test.trace命令,出现debug记录的结果
上面是时间片面板(Timeline panel),下面是分析面板(Profilepanel)
时间片面板(Timeline panel):描述当每个线程和方法启动和停止
分析面板(Profile panel):提供了内部方法调用的总结
分析面板中参数的意义
Exclusive time是该函数本身基本操作(不包括子函数调用)的时间。
Inclusive time是该函数调用所用的时间(包括子函数调用)的时间。
列1:"Name"表示函数名。
双击函数名,可以看到在上半界面是时间轴面图(Timeline Panel)看他的所消耗的时间段。(用粗的线段标注)。
双击函数名左边的"+"展开后可以看到,该函数的"parents"和"children"
列2:"incl%"表示函数的Inclusive time在整个MethodTracing时间里占的百分比。
列3:"Inclusive"表示Inclusive time。
列4:"Excl%"表示函数的Exclusive time在整个MethodTracing时间里占的百分比。
列5:"Exclusive"表示Exclusive time。
列6:"Calls+RecurCalls/Total"表示对函数的调用次数(包括递归调用)。如图2的nativeFinished()那列为"14+0"表示14次非递归调用,0次递归调用.
列7:新的版本(比如2.1)还有"time/calls"表示平均的调用时间(即Inclusive time/ total calls)。如图3。来自google文档的图2感觉有老了。
英语 |
中文 |
Incl |
调用方法占用时间百分比 |
Inclusive |
调用方法时间(ms)(包括了所有方法的调用) |
Excl |
执行方法占用时间百分比 |
Exclusive |
执行方法占用时间(ms)(不包括子方法的调用) |
Calls+Recur Calls/Total |
调用和重复调用的次数 |
Time/Call |
总的时间(ms) |
生成函数调用关系图
dmtracedump -g aa.png calc.trace
但是我失败了,出现错误:
ERROR: unable to read 1829330 bytes from trace file
Cannot read trace.
dmtracedump的使用方法:
dmtracedump [-ho] [-s sortable][-d trace-base-name][-g outfile]<trace-base-name>
参数 |
描述 |
-d <trace-base-name> |
Trace 文件的名称 |
-g <outfile> |
需要输出的问题 |
-h |
使用HTML输出 |
-o |
存储跟踪文件,而不是分析文件 |
-t <percent> |
最低门槛,包括子节点图中(孩子接点的包容性的时间占母接点包容性的时间)。如果不使用此选项,默认阈值是20%。
|