android traceview工具,[Android]Android TraceView工具使用

一、 选择跟踪范围

在想要根据的代码片段之间使用以下两句代码

Debug.startMethodTracing("love_world_");

Debug.stopMethodTracing();

例如,onCreate与onStart方法之间方法跟踪

public class MainActivity extends Activity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

Debug.startMethodTracing("Love_World_");

}

@Override

protected void onStart() {

super.onStart();

Debug.stopMethodTracing();

}

}

二、添加SD卡访问权限

如果不添加,执行项目会出现以下异常

java.lang.RuntimeException:Unable to open trace file ‘/mnt/sdcard/Love_World_.trace‘: Permission denied

三 、 导出traceview文件

1  首先执行项目,查看trace文件是否生成

进入shell模式

adb shell

查看是否已经生成这个文件

ls sdcard/Love_World_.trace

Ctrl + C 退出adb shell模式

2 导出trace文件

adb pull sdcard/Love_World_.trace

四、 打开trace文件

打开trace文件需要Android提供的traceview.bat工具,工具所在目录:sdk\tools\traceview.bat,

有两种方式执行:

1) 在命令行中切换到此目录

2) 将此目录添加到系统环境变量中

//  cmd在calc.trace所在目录执行

traceview C:\Users\YourName\Desktop\Love_World_.trace

其中“C:\Users\YourName\Desktop\” 表示trace所在你系统中的目录,此工具需要输入trace文件的绝对路径才行

五、 TraceView工具用途

有两方面用途:

1  查看跟踪代码的执行时间,分析哪些是耗时操作

2  可以用于跟踪方法的调用,尤其是Android Framework层的方法调用关系

获取方法的调用顺序

1. 在traceview中搜索响应的方法名不能使用大写字母

2. 搜索出的方法会自动展开,其中包含Parents 和 Children 两组信息

3. 点击Parents下的方法名,直接跳转到调用当前的方法处。Children相反

1356274910_3864.gif

六、异常处理

1 异常处理

‘C:\Windows\system32\java.exe‘ 不是内部或外部命令,也不是可运行的程序

或批处理文件。

SWT folder ‘‘ does not exist.

Please set ANDROID_SWT to point to the folder containing swt.jar for your platfo

rm.

配置Java环境变量,把java bin 添加到系统环境变量PATH中

2 异常信息

The standalone version of traceview is deprecated.

Please use Android Device Monitor (tools/monitor) instead.

Failed to read the trace filejava.io.IOException: Key section does not have an *

end marker

at com.android.traceview.DmTraceReader.parseKeys(DmTraceReader.java:420)

at com.android.traceview.DmTraceReader.generateTrees(DmTraceReader.java:

91)

at com.android.traceview.DmTraceReader.(DmTraceReader.java:87)

at com.android.traceview.MainWindow.main(MainWindow.java:286)

通常是trace文件有异常,再重新生成并导出试试

七、 相关资料:

原文:http://www.cnblogs.com/webapplee/p/3774056.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值