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




Java,可以使用StackTraceElement类来获取当前方法行号方法、类文件名,以及调用该方法方法的信息。下面是示例代码: ``` StackTraceElement[] stackTraceElements = Thread.currentThread().getStackTrace(); if (stackTraceElements.length >= 2) { // 获取当前方法信息 StackTraceElement currentMethod = stackTraceElements[1]; String className = currentMethod.getClassName(); String methodName = currentMethod.getMethodName(); String fileName = currentMethod.getFileName(); int lineNumber = currentMethod.getLineNumber(); System.out.println("当前方法信息:"); System.out.println("类:" + className); System.out.println("方法:" + methodName); System.out.println("文件名:" + fileName); System.out.println("行号:" + lineNumber); // 获取调用该方法方法信息 StackTraceElement callerMethod = stackTraceElements[2]; String callerClassName = callerMethod.getClassName(); String callerMethodName = callerMethod.getMethodName(); String callerFileName = callerMethod.getFileName(); int callerLineNumber = callerMethod.getLineNumber(); System.out.println("调用该方法方法信息:"); System.out.println("类:" + callerClassName); System.out.println("方法:" + callerMethodName); System.out.println("文件名:" + callerFileName); System.out.println("行号:" + callerLineNumber); } ``` 需要注意的是,获取方法信息的代码必须位于该方法内部。如果将该代码放在其他方法,则获取到的信息可能是其他方法的信息。另外,由于获取方法信息的代码本身也会被添加到堆栈跟踪,因此需要使用`stackTraceElements[2]`来获取调用该方法方法的信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值