查看源码的调用关系
标签(空格分隔): 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文件