[关闭]
@guhuizaifeiyang 2017-01-03T02:42:45.000000Z 字数 1211 阅读 1728

查看源码的调用关系

Android开发


1. 查看当前堆栈

在程序中加入代码,使可以在logcat中看到打印出的当前函数调用关系

  1. new Exception("print trace").printStackTrace();

在回调中使用第二个方法比较有效

2. 查看当前调用堆栈

  1. Map<Thread, StackTraceElement[]> ts = Thread.getAllStackTraces();
  2. StackTraceElement[] ste = ts.get(Thread.currentThread());
  3. for (StackTraceElement s : ste) {
  4. Log.d("Info ", s.toString());
  5. }

3. 查看当前方法的调用堆栈

  1. Debug.getCallers(int depth)

4. 使用Android 自带的TraceView工具 - TraceView工具使用

1、 选择跟踪范围
在想要根据的代码片段之间使用以下两句代码

  1. Debug.startMethodTracing("/data/data/com.example.applicationtest/a.trace");
  2. Debug.stopMethodTracing();

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

  1. public class MainActivity extends Activity {
  2. @Override
  3. protected void onCreate(Bundle savedInstanceState) {
  4. super.onCreate(savedInstanceState);
  5. setContentView(R.layout.activity_main);
  6. // 指定trace文件的输出路径
  7. Debug.startMethodTracing("/data/data/com.example.applicationtest/a.trace");
  8. }
  9. @Override
  10. protected void onStart() {
  11. super.onStart();
  12. Debug.stopMethodTracing();
  13. }
  14. }

2、添加访问权限

  1. <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

3、 导出traceview文件

  1. adb pull /data/data/com.example.applicationtest/a.trace <des>

4、 打开trace文件

打开trace文件需要Android提供的traceview.bat工具,工具所在目录:sdk\tools\traceview.bat, 有两种方式执行:
1) 在命令行中切换到此目录
2) 将此目录添加到系统环境变量中

  1. traceview <file>

或者使用Android Device Monitor,然后File -> Open File -> 选择trace文件

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注