android 查看线程堆栈,Android线程——StackTraceElement线程运行栈的探索

本文详细介绍了如何使用StackTraceElement获取并解析Android应用中线程的堆栈信息,通过示例展示了如何获取类名、方法名、行号等关键信息,并分析了在Android中由于Dalvik调用导致的栈位移现象。
摘要由CSDN通过智能技术生成

介绍

StackTraceElement[]中保存了一条线程中所有调用的方法。其中每个方法的信息包含在一个StackTraceElement对象中。

获取StackTraceElement中的信息

element.getClassName(); //获取类名

element.getMethodLine(); //获取方法名

element.getMethodName(); //获取方法名

element.getFileName(); //获取包含类的文件名

StackTraceElement[]中的信息

StackTracelElement[]是一个的数组,以下标0为开始,其中在Java比较有用的是第3个,在Android中比较有用的是第4个,因为在Android中多了一个Dalvik的调用,所以实际Java中的第3位向后移动了一个位置,变成第4位。

这个比较有用的StackTraceElement保存了实际调用该方法的方法信息。

//下面方法能够打印一组当前线程的StackTraceElement[]信息:

public static String showAllElementsInfo() {

String print = "";

int count = 0;

//从当前线程中获取所有的StackTraceElement

StackTraceElement[] stackTraceElements = Thread.currentThread().getStackTrace();

for (StackTraceElement stackTraceElement : stackTraceElements) {

count++;

print += String.format("ClassName:%s " +

"\nMethodName:%s " +

"\nMethodLine:%d " +

"\n当前是第%d个 " +

"\n---------------------------- " +

"\n ",

stackTraceElement.getClassName(),

stackTraceElement.getMethodName(),

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值