查看源码的调用关系

查看源码的调用关系

标签(空格分隔): 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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值