查看源码的调用关系

来源:互联网 发布:minecraftpe凡家物语js 编辑:程序博客网 时间:2024/06/03 23:43

查看源码的调用关系

标签(空格分隔): Android开发


1. 查看当前堆栈

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

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

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

2. 查看当前调用堆栈

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

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

Debug.getCallers(int depth)

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

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

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

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

public class MainActivity extends Activity {      @Override      protected void onCreate(Bundle savedInstanceState) {          super.onCreate(savedInstanceState);          setContentView(R.layout.activity_main);          // 指定trace文件的输出路径        Debug.startMethodTracing("/data/data/com.example.applicationtest/a.trace");      }      @Override      protected void onStart() {          super.onStart();          Debug.stopMethodTracing();      }  }  

2、添加访问权限

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

3、 导出traceview文件

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

4、 打开trace文件

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

traceview <file>  

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

0 0
原创粉丝点击