[转]Android TraceView工具使用
2013-12-04 16:21
417 查看
一、 选择跟踪范围
在想要根据的代码片段之间使用以下两句代码
[java] view plaincopyprint?
Debug.startMethodTracing("love_world_");
Debug.stopMethodTracing();
例如,onCreate与onStart方法之间方法跟踪
[java] view plaincopyprint?
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卡访问权限
[html] view plaincopyprint?
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>
如果不添加,执行项目会出现以下异常
[java] view plaincopyprint?
java.lang.RuntimeException:Unable to open trace file '/mnt/sdcard/Love_World_.trace': Permission denied
三 、 导出traceview文件
1 首先执行项目,查看trace文件是否生成
进入shell模式
[sql] view plaincopyprint?
adb shell
查看是否已经生成这个文件
[plain] view plaincopyprint?
ls sdcard/Love_World_.trace
Ctrl + C 退出adb shell模式
2 导出trace文件
[plain] view plaincopyprint?
adb pull sdcard/Love_World_.trace
四、 打开trace文件
打开trace文件需要Android提供的traceview.bat工具,工具所在目录:sdk\tools\traceview.bat, 有两种方式执行:
1) 在命令行中切换到此目录
2) 将此目录添加到系统环境变量中
[plain] view plaincopyprint?
// 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相反
六、异常处理
1 异常处理
[plain] view plaincopyprint?
'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 异常信息
[plain] view plaincopyprint?
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.<init>(DmTraceReader.java:87)
at com.android.traceview.MainWindow.main(MainWindow.java:286)
通常是trace文件有异常,再重新生成并导出试试
七、 相关资料:
念茜 : Android代码调试工具 traceview 和 dmtracedump的波折演绎
原文地址: http://blog.csdn.net/love_world_/article/details/8223805
在想要根据的代码片段之间使用以下两句代码
[java] view plaincopyprint?
Debug.startMethodTracing("love_world_");
Debug.stopMethodTracing();
例如,onCreate与onStart方法之间方法跟踪
[java] view plaincopyprint?
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卡访问权限
[html] view plaincopyprint?
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>
如果不添加,执行项目会出现以下异常
[java] view plaincopyprint?
java.lang.RuntimeException:Unable to open trace file '/mnt/sdcard/Love_World_.trace': Permission denied
三 、 导出traceview文件
1 首先执行项目,查看trace文件是否生成
进入shell模式
[sql] view plaincopyprint?
adb shell
查看是否已经生成这个文件
[plain] view plaincopyprint?
ls sdcard/Love_World_.trace
Ctrl + C 退出adb shell模式
2 导出trace文件
[plain] view plaincopyprint?
adb pull sdcard/Love_World_.trace
四、 打开trace文件
打开trace文件需要Android提供的traceview.bat工具,工具所在目录:sdk\tools\traceview.bat, 有两种方式执行:
1) 在命令行中切换到此目录
2) 将此目录添加到系统环境变量中
[plain] view plaincopyprint?
// 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相反
六、异常处理
1 异常处理
[plain] view plaincopyprint?
'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 异常信息
[plain] view plaincopyprint?
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.<init>(DmTraceReader.java:87)
at com.android.traceview.MainWindow.main(MainWindow.java:286)
通常是trace文件有异常,再重新生成并导出试试
七、 相关资料:
念茜 : Android代码调试工具 traceview 和 dmtracedump的波折演绎
原文地址: http://blog.csdn.net/love_world_/article/details/8223805
相关文章推荐
- 正确使用Android性能分析工具——TraceView
- Android学习之性能工具traceView使用
- [转载]正确使用Android性能分析工具——TraceView
- 正确使用Android性能分析工具——TraceView
- 正确使用Android性能分析工具——TraceView
- Android编程TraceView工具使用方法
- Android 性能优化 之 TraceView工具的使用
- 【Java/Android性能优3】Android性能调优工具TraceView使用介绍
- 【Android测试工具】01. Android TraceView工具使用详解
- 正确使用Android性能分析工具——TraceView
- 正确使用Android性能分析工具——TraceView
- 正确使用Android性能分析工具——TraceView
- 正确使用Android性能分析工具——TraceView
- Android性能分析工具Traceview的使用
- 正确使用Android性能分析工具——TraceView
- 正确使用 Android 性能分析工具——TraceView
- Android TraceView工具使用
- Android 性能优化 二 TraceView工具的使用
- 正确使用 Android 性能分析工具——TraceView
- 正确使用 Android 性能分析工具——TraceView