分析与Traceview和dmtracedump

Traceview是一个图形查看执行日志,您创建使用Debug类日志跟踪信息在你的代码。Traceview可以帮助您调试您的应用程序和配置它的性能。

使用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%

 


你可能感兴趣的:(html,存储,图形)