Android/Java获取当前代码执行时所在的文件名/方法名/行号

在做Android开发的过程中,都会遇到程序崩溃的情况,这时LogCat会显示逐层显示出崩溃所在位置,这对于解决问题来说非常方便。但是方便的同时,也需要想一想这是怎么实现的或者能不能加以利用。
经过一番查找,目前发现都是通过获取StackTrace信息实现的,这是Java JDK提供的方法。至于具体内部原理,还需进一步调查。现只对获取方式进行简单总结,如有不对的地方还请指正。

一、利用Thread.currentThread().getStackTrace()
工具类:
CodeLine.java

package com.example.codeline;


publicclassCodeLine{
//通过静态方法调用 Thread.currentThread().getStackTrace() 获取当前函数栈时, 已多加了两层方法调用.
/ /Main.main() -->CodeLine.getLineNumber() --> Thread.getStackStrace()

privatestaticint stackIndex = 2;

publicstatic String getFileName(){
return Thread.currentThread().getStackTrace()[originStackIndex].getFileName();
}
publicstatic String getClassName(){
return Thread.currentThread().getStackTrace()[originStackIndex].getClassName();
}
publicstatic String getMethodName(){
return Thread.currentThread().getStackTrace()[originStackIndex].getMethodName();
}
publicstaticintgetLineNumber(){
return Thread.currentThread().getStackTrace()[originStackIndex].getLineNumber();
}
}

测试代码:
Main.java:
package com.example.codeline;

public class TestClass
{
public static void main(String[] args)
{
System.out.format("  FileName:\t%s\n", CurrentLineInfo.getFileName());
System.out.format(" ClassName:\t%s\n",CurrentLineInfo.getClassName());
System.out.format("MethodName:\t%s\n",CurrentLineInfo.getMethodName());
System.out.format("LineNumber:\t%s\n\n",CurrentLineInfo.getLineNumber());
}

}


测试输出:
      FileName: TestClass.java
  ClassName: com.example.codeline.TestClass
MethodName: main
  LineNumber: 10



二、利用new Throwable().getStackTrace() 也能得到同样信息

测试代码:
TestClass.java

package com.example.codeline;

public class TestClass
{
public static void main(String[] args)
{
test();
}


public static void test()
{
getCaller();
}


public static void getCaller()
{
StackTraceElement stack[] = (new Throwable()).getStackTrace();
for (int i = 0; i < stack.length; i++)
{
StackTraceElement s = stack[i];
System.out.format("  FileName:%d\t%s\n", i, s.getFileName());
System.out.format(" ClassName:%d\t%s\n", i, s.getClassName());
System.out.format("MethodName:%d\t%s\n", i, s.getMethodName());
System.out.format("LineNumber:%d\t%s\n\n", i, s.getLineNumber());
}
}
}
测试输出:
  FileName:0TestClass.java
  ClassName:0 com.example.codeline.TestClass
MethodName:0 getCaller
LineNumber:0 17


  FileName:1 TestClass.java
 ClassName:1 com.example.codeline.TestClass
MethodName:1 test
LineNumber:1 12


  FileName:2 TestClass.java
 ClassName:2 com.example.codeline.TestClass
MethodName:2 main
LineNumber:2 7




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值