首页 > 程序开发 > 移动开发 > Android >

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

2017-04-11

Android Java获取当前代码执行时所在的文件名 方法名 行号,在做Android开发的过程中,都会遇到程序崩溃的情况,这时LogCat会显示逐层显示出崩溃所在位置,这对于解决问题来说非常方便。但是方便的同时,也需要想一想这是怎么实现的或者能不能加以利用。

Android/Java获取当前代码执行时所在的文件名/方法名/行号,在做Android开发的过程中,都会遇到程序崩溃的情况,这时LogCat会显示逐层显示出崩溃所在位置,这对于解决问题来说非常方便。但是方便的同时,也需要想一想这是怎么实现的或者能不能加以利用。
经过一番查找,目前发现都是通过获取StackTrace信息实现的,这是Java JDK提供的方法。至于具体内部原理,还需进一步调查。现只对获取方式进行简单总结,如有不对的地方还请指正。
一、利用Thread.currentThread().getStackTrace()
工具类:
CodeLine.java:
package com.example.codeline;
public class CodeLine{
//通过静态方法调用Thread.currentThread().getStackTrace()获取当前函数栈时, 已多加了两层方法调用.
/ /Main.main() --> CodeLine.getLineNumber() --> Thread.getStackStrace()
private static int stackIndex = 2;
public static String getFileName() {
return Thread.currentThread().getStackTrace()[originStackIndex].getFileName();
}
public static String getClassName() {
return Thread.currentThread().getStackTrace()[originStackIndex].getClassName();
}
public static String getMethodName() {
return Thread.currentThread().getStackTrace()[originStackIndex].getMethodName();
}
public static int getLineNumber() {
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:0 TestClass.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
相关文章
最新文章
热点推荐