@guhuizaifeiyang
2017-01-03T10:42:45.000000Z
字数 1211
阅读 1823
Android开发
在程序中加入代码,使可以在logcat中看到打印出的当前函数调用关系
new Exception("print trace").printStackTrace();
在回调中使用第二个方法比较有效
Map<Thread, StackTraceElement[]> ts = Thread.getAllStackTraces();
StackTraceElement[] ste = ts.get(Thread.currentThread());
for (StackTraceElement s : ste) {
Log.d("Info ", s.toString());
}
Debug.getCallers(int depth)
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文件