(1) 第一种使用方法演示
在想要根据的代码片段之间使用以下两句代码
Debug.startMethodTracing("love_world_"); Debug.stopMethodTracing();
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(); } }
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>
java.lang.RuntimeException:Unable to open trace file '/mnt/sdcard/Love_World_.trace': Permission denied
1 首先执行项目,查看trace文件是否生成
进入shell模式
adb shell
ls sdcard/Love_World_.trace
adb pull sdcard/Love_World_.trace
// cmd在calc.trace所在目录执行 traceview C:\Users\YourName\Desktop\Love_World_.trace
在新版本的SDK 会有以下提示:
The standalone version of traceview is deprecated. Please use Android Device Monitor (tools/monitor) instead.
'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.
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)
3. 没有SD卡会出现异常
Unable to open trace file '/sdcard/Love_World_.trace': Permission denied Caused by: java.lang.RuntimeException: Unable to open trace file '/sdcard/Love_World_.trace': Permission denied
(2) 第二种使用方法演示
Eclipse -> DDMS -> Start Method Profiling
二者的区别,第一种方式更精确到方法,不方便的地方是自己需要添加方法并且要导出文件,第二种方式的优缺点刚好相反。
细节详见官方文档:
http://developer.android.com/tools/help/shell.html
有两方面用途:
1 查看跟踪代码的执行时间,分析哪些是耗时操作
2 可以用于跟踪方法的调用,尤其是Android Framework层的方法调用关系
获取方法的调用顺序
1. 在traceview中搜索响应的方法名不能使用大写字母
2. 搜索出的方法会自动展开,其中包含Parents 和 Children 两组信息
3. 点击Parents下的方法名,直接跳转到调用当前的方法处。Children相反
表1-1 Profile Panel各列作用说明
列名 |
描述 |
Name |
该线程运行过程中所调用的函数名 |
Incl Cpu Time |
某函数占用的CPU时间,包含内部调用其它函数的CPU时间 |
Excl Cpu Time |
某函数占用的CPU时间,但不含内部调用其它函数所占用的CPU时间 |
Incl Real Time |
某函数运行的真实时间(以毫秒为单位),内含调用其它函数所占用的真实时间 |
Excl Real Time |
某函数运行的真实时间(以毫秒为单位),不含调用其它函数所占用的真实时间 |
Call+Recur Calls/Total |
某函数被调用次数以及递归调用占总调用次数的百分比 |
Cpu Time/Call |
某函数调用CPU时间与调用次数的比。相当于该函数平均执行时间 |
Real Time/Call |
同CPU Time/Call类似,只不过统计单位换成了真实时间 |
有两个问题需要解决:
1. 如何定位到所关心的地方?
上面只是介绍了如何使用TraceView且有两种用法,但是有时使用第一种方式范围又不太精确,使用第二种添加代码的方式,可能有些地方又监听不到。这种情况可以尝试把开始或者结束放到延迟线程中,延迟一段时间在执行开始或者结束。
2. 如何查找出哪些地方比较耗时?
TraceView罗列出了是所有监听到的方法,当然也包括Android系统很多方法的耗时,如何在这么多方法里面查找到自己关心的? 可以通过TraceView 底部的find 来查找,通常Android app都是有包名的,可以先针对某些关心的列排序后,在通过包名进行一个个查找,这些就省去自己筛选出自己app 方法耗时排行的时间。
念茜 : Android代码调试工具 traceview 和 dmtracedump的波折演绎
原文地址: http://blog.csdn.net/love_world_/article/details/8223805