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

时间:2022-05-27 10:30:47
在做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